|              |     | RRRRRRRR<br>RRRRRRRR<br>RRRRRRRR | RRRR |           | VVV<br>VVV | VVV<br>VVV |               | RRRRRR | RRRRRRR<br>RRRRRRR<br>RRRRRRR |
|--------------|-----|----------------------------------|------|-----------|------------|------------|---------------|--------|-------------------------------|
| DDD          | DDD | RRR                              | RRR  | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
|              | DDD | RRR                              | RRR  | III       | VVV        | VVV        | EEE           | RRR    | RRR                           |
| DDD          | DDD | RRR                              | RRR  | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
| DDD          | DDD | RRR                              | RRR  | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
|              | DDD | RRR                              | RRR  | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
|              | DDD | RRR                              | RRR  | III       | VVV        | VVV        | EEE           | RRR    | RRR                           |
| DDD          | DDD | RRRRRRRR                         |      | 111       | VVV        | VVV        | EEEEEEEEEE    |        | RRRRRRR                       |
| DDD          | DDD | RRRRRRRR                         |      | III       | VVV        | VVV        | EEEEEEEEEEE   |        | RRRRRRR                       |
| DDD          | DDD | RRRRRRRR                         |      | 111       | VVV        | VVV        | EEEEEEEEEEE   |        | RRRRRRR                       |
| DDD          | DDD | RRR RR                           |      | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
|              | DDD | RRR RR                           |      | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
| DDD          | DDD | RRR RR                           |      | III       | VVV        | VVV        | EEE           | RRR    | RRR                           |
| DDD          | DDD | RRR                              | RRR  | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
|              | DDD | RRR                              | RRR  | 111       | VVV        | VVV        | EEE           | RRR    | RRR                           |
|              | DDD | RRR                              | RRR  |           | VVV        | VVV        | EEE           | RRR    | RRR                           |
| DDDDDDDDDDDD |     | RRR                              | RRR  | 111111111 | V          |            | EEEEEEEEEEEEE | RRR    | RRR                           |
| DDDDDDDDDDDD |     | RRR                              | RRR  | 111111111 | V          |            | EEEEEEEEEEEEE | RRR    | RRR                           |
| DDDDDDDDDDDD |     | RRR                              | RRR  | 111111111 | V          | /V         | EEEEEEEEEEEEE | RRR    | RRR                           |

RRRR

XF VO

| XX<br>XX<br>XX<br>XX | XX<br>XX<br>XX<br>XX | FFFFFFFFF<br>FFFFFFFFF<br>FF<br>FF | DDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD | RRR<br>RR<br>RR | RRRRR<br>RRRRR<br>RR<br>RR | VV VV<br>VV VV<br>VV VV<br>VV VV | EEEEEEEEEE<br>EEEEEEEEEEE    | RRRRI<br>RRRRI<br>RR<br>RR | RRRR<br>RR<br>RR<br>RR |  |
|----------------------|----------------------|------------------------------------|----------------------------------------|-----------------|----------------------------|----------------------------------|------------------------------|----------------------------|------------------------|--|
| XX<br>XX<br>XX       | XX<br>XX             | FFFFFFF<br>FFFFFFF<br>FF           | DD                                     | RRR<br>RR       | RRRRR<br>RRRRR<br>RR<br>RR | VV VV<br>VV VV<br>VV VV          | EEEEEEEEE<br>EEEEEEEEE<br>EE | RR                         | RRRR<br>RR<br>RR       |  |
| XX<br>XX<br>XX       | XX<br>XX<br>XX       | FF<br>FF                           | DD | RR<br>RR<br>RR  | RR<br>RR<br>RR<br>RR       | VV VV                            |                              | RR<br>RR<br>RR<br>RR       | RR<br>RR<br>RR<br>RR   |  |



Page

.TITLE XFDRIVER - DR32 DRIVER .IDENT 'V04-000'

COPYRIGHT (c) 1978, 1980, 1982, 1984 BY DIGITAL EQUIPMENT CORPORATION, MAYNARD, MASSACHUSETTS. ALL RIGHTS RESERVED.

THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE AND WITH THE INCLUSION OF THE ABOVE COPYRIGHT NOTICE. THIS SOFTWARE OR ANY OTHER COPIES THEREOF MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY OTHER PERSON. NO TITLE TO AND OWNERSHIP OF THE SOFTWARE IS HEREBY TRANSFERRED.

THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE AND SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT CORPORATION.

DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY OF ITS SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY DIGITAL.

FACILITY: EXECUTIVE, I/O DRIVERS

ABSTRACT:

THIS MODULE IS THE DRIVER FOR THE DR32.

ENVIRONMENT: KERNEL MODE, NON-PAGED

AUTHOR: STEVE BECKHARDT, CREATION DATE: 23-FEB-1979

MODIFIED BY:

V03-002 TCM0002 Trudy C. Matthews 29-Feb-1983 Update CPUDISP that determines if this is a DR780 or a DR750 to work on an 11/790 (take the DR780 path).

V03-001 EAD0068 Elliott A. Drayton 01-Jul-1982 Add code to prevent race condition with HALT bit.

V02-012 TCM0001 Trudy C. Matthews 31-Jul-1981 Change all "722"s to "730"s.

V02-011 EAD0011 Elliott A. Drayton 13-Feb-1981 Add code to raise and lower IPL to prevent race condition.

V02-010 SRB0006 Steve Beckhardt 17-Sep-1979 Modified the driver to support the DR750.

7890123456789012345678901234

G 15 - DR32 DRIVER 16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 Page 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1 XFDRIVER VO4-000 0000 58 ;--

XF VO

XF

V

XFDRIVER VO4-000

Page

(2)

16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1

```
0000
0000
0000
0000
00000044
                                                         IRPE$L_CBLKADR=IRPE$L_BCNT2+4
IRPE$L_BBLKADR=IRPE$L_BCNT2+8
                                                                                                                                                                        OFFSET OF COMMAND BLOCK ADDRESS OFFSET OF BUFFER BLOCK ADDRESS
                                               118
                                                        : DR32 DEVICE REGISTER DEFINITIONS
                                              SDEFINI DR
                                                                                                     DR DCR,0,<-

<ADPTYP,8>,-

<ID2ERR,M>,-

<ID2TOC,M>,-

<ID2TO,M>,-

<STALL M>,-
                                                                                DR DCR
VIELD
                                                                                                                                                                        : DR32 CONTROL REGISTER
                                                                                                                                                                     ADAPTER TYPE
ID2 ERROR
ID2 TIMEOUT CAUSE
ID2 TIMEOUT
DD1 STALL
ID1 ERROR
ID1 TIMEOUT CAUSE
ID1 TIMEOUT
READ DATA SUBSTITUTE
CORRECTED READ DATA
DCR HALT
DCR ABORT INTERRUPT
PACKET INTERRUPT
INTERRUPT ENABLE
RESERVED
ADAPTER POWER UP
ADAPTER POWER UP
ADAPTER POWER DOWN
EXTERNAL ABORT
NOTE: THE NEXT 7 BITS ARE USED BY
DR750 ONLY. THE DR780 HAS THESE BITS
IN THE DR UTL REGISTER.
FORCE CONTROL INTERCONNECT PARITY ERROR
FORCE DATA INTERCONNECT PARITY ERROR
ENABLE D.I. PARITY ERROR
CONTROL INTERCONNECT PARITY ERROR
CONTROL INTERCONNECT PARITY ERROR
CONTROL INTERCONNECT PARITY ERROR
CONTROL INTERCONNECT PARITY ERROR
DATA INTERCONNECT PARITY ERROR
PARITY ERROR (OR OF LAST 3 BITS)
                                                                                                      <STALL, M>,-
<ID1ERR, M>,-
                                                                                                      <ID1TOC, M>,-
<ID1TO, M>,-
<RDS, M>,-
                                                                                                      <CRD, M>,-
<DCRHLT, M>,-
                                                                                                      <DCRABT,,M>,-
                                                                                                      <PKTINT,,M>,-
                                                                                                      <INTENB,,M>,-
                                                                                                     <,1>,-
<PWR_UP,,M>,-
<PWR_DN,,M>,-
<EXTABT,,M>,-
                            0004
                            0004
                            0004
                            0004
                            0004
                            0004
                            0004
                                                                                                     <FCIPE.,M>,-
<FDIPE.,M>,-
<ENPEAB.,M>,-
<WCSPE.,M>,-
                            0004
                            0004
                            0004
                            0004
                                                                                                      <CIPE, M>.-
<DIPE, M>.-
<PARERR, M>,-
                            0004
                            0004
                            0004
                            0004
                                               156
157 : DCR CONTROL FIELD A CODES (USED WHEN WRITING TO DCR)
                            0004
                            0004
                                              158
159 DCR K CLRPWRUP=*X100
160 DCR K CLRPWRUP=*X200
161 DCR K CLRABTINT=*X400
162 DCR K CLRINTENB=*X500
163 DCR K SETINTENB=*X600
164 DCR K CLRHLT=*X700
165
                            0004
 00000100
                                                                                                                                                                         ; CLEAR POWER UP
                            00000200
00000400
00000500
00000600
00000700
                                                                                                                                                                        : CLEAR POWER DOWN
                                                                                                                                                                        : CLEAR ABORT INTERRUPT
                                                                                                                                                                        CLEAR INTERRUPT ENABLE
SET INTERRUPT ENABLE
CLEAR HALT
                                               166 : DCR CONTROL FIELD B CODES (USED WHEN WRITING TO DCR)
00001000
00002000
00003000
00004000
00005000
                                               168 DCR_K_CLRCRD=*X1000
169 DCR_K_SETEXTABT=*X2000
170 DCR_K_CLRPKTINT=*X3000
171 DCR_K_RESET=*X4000
172 DCR_K_SETOSQTST=*X5000
173 DCR_K_CLROSQTST=*X6000
                                                                                                                                                                         : CLEAR CRD
                                                                                                                                                                       SET EXTERNAL ABORT
CLEAR PACKET INTERRUPT
RESET
SET OSEQ TEST
CLEAR OSEQ TEST
```

| 0004<br>0008<br>0008<br>0008<br>0008<br>0008<br>0008         | 174<br>175 SDEF<br>176<br>177<br>178<br>179<br>180                                      | DR_UTL_VIELD                                                                                                                                                                             | DR_UTL,0<br><rate,8><br/>&lt;,3&gt;,-<br/><valid,,< th=""><th>.BLKL</th><th>1</th><th></th><th>LITY REGISTER</th></valid,,<></rate,8>                                                                            | .BLKL                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | LITY REGISTER                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0008<br>0008<br>0008<br>0008<br>0008<br>0008<br>0008         | 178<br>179<br>180<br>181<br>182<br>183<br>184<br>185<br>186<br>187<br>188<br>189<br>190 |                                                                                                                                                                                          | <5C105                                                                                                                                                                                                           | -                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                            | RESI<br>NOTI<br>DR7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | A RATE ERVED VALID ERVED E: THE NEXT 7 BITS ARE USED BY BO ONLY. THE DR750 HAS THESE BITS THE DR DCR REGISTER. CE CONTROL INTERCONNECT PARITY ERR. CE DATA INTERCONNECT PARITY ERROR BLE D.I. PARITY ERROR ABORT PARITY ERROR TROL INTERCONNECT PARITY ERROR A INTERCONNECT PARITY ERROR A INTERCONNECT PARITY ERROR ITY ERROR (OR OF LAST 3 BITS) |
| 0008<br>0008<br>000C<br>000C<br>000C<br>000C                 | 192<br>193 <b>\$DEF</b><br>194<br>195<br>196<br>197<br>198                              | DR WCSA<br>_VIELD                                                                                                                                                                        | DR_WCSA,<br><sel,,m><br/><addr,10<br>&lt;,20&gt;,-<br/><wcs,,m></wcs,,m></addr,10<br></sel,,m>                                                                                                                   | .BLKL<br>0.<-                                                                                                                                                                                                           | 1                                                                                                                                                                                                                                                                                                                          | : SELI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ADDRESS  ECT (LOW OR HI PART OF MICRO WORD)  RESS ERVED D WCS FLAG (DR750 ONLY)                                                                                                                                                                                                                                                                    |
| 000C<br>000C<br>000C                                         | 200<br>201<br>202<br>203                                                                | _VIELD                                                                                                                                                                                   |                                                                                                                                                                                                                  |                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | AL STORE ADDRESS (DR750 ONLY)                                                                                                                                                                                                                                                                                                                      |
| 000C<br>0010<br>00014                                        | 204 \$DEF<br>205<br>206                                                                 | DR_WCSD                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                    |
| 0014<br>0014                                                 | 207<br>208 SDEF                                                                         | DR_SBIAD                                                                                                                                                                                 |                                                                                                                                                                                                                  |                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ADDRESS                                                                                                                                                                                                                                                                                                                                            |
| 0018<br>0018                                                 | 209<br>210 SDEF                                                                         |                                                                                                                                                                                          |                                                                                                                                                                                                                  |                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | BYTE COUNT                                                                                                                                                                                                                                                                                                                                         |
| 001C<br>001C<br>0020                                         | 211<br>212 SDEF<br>213                                                                  |                                                                                                                                                                                          |                                                                                                                                                                                                                  |                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | BYTE COUNT                                                                                                                                                                                                                                                                                                                                         |
| 0020<br>0020<br>0020                                         | 214<br>215<br>216                                                                       | DEFINE                                                                                                                                                                                   | USER CO                                                                                                                                                                                                          | NTROL                                                                                                                                                                                                                   | REGISTER                                                                                                                                                                                                                                                                                                                   | R (GO BI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D                                                                                                                                                                                                                                                                                                                                                  |
| 00200 0020                                                   | 218 .= X200                                                                             |                                                                                                                                                                                          |                                                                                                                                                                                                                  |                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                            | ; STAI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RTS ON 2ND PAGE OF DR ADDRESS SPACE                                                                                                                                                                                                                                                                                                                |
| 0200<br>0204<br>0204<br>0204<br>0204<br>0204<br>0204<br>0204 | 219<br>220 \$DEF<br>221<br>222<br>223<br>224<br>225<br>226<br>227<br>228                | >                                                                                                                                                                                        | <gū,,m>,<br/>&lt;,31&gt;,-</gū,,m>                                                                                                                                                                               | 0,<-                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                            | : GO I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                    |
|                                                              | 0010<br>0020<br>0020<br>0020<br>0020<br>0020                                            | 001C 211<br>001C 212 \$DEF<br>0020 213<br>0020 214<br>0020 215<br>0020 216<br>0020 217<br>0020 218 .=^x200<br>0200 219<br>0200 220 \$DEF<br>0204 221<br>0204 222<br>0204 223<br>0204 223 | 001C 211<br>001C 212 \$DEF DR_DDIBC<br>0020 213<br>0020 214<br>0020 215<br>0020 216<br>0020 217<br>00200 218 .= x200<br>0200 219<br>0200 220 \$DEF DR_USER_VIELD<br>0204 221<br>0204 222<br>0204 223<br>0204 223 | 001C 211<br>001C 212 \$DEF DR_DDIBCNT<br>0020 213<br>0020 214<br>0020 215<br>0020 216<br>0020 217<br>0020 218 .=^x200<br>0200 220 \$DEF DR_USER<br>0204 221<br>0204 221<br>0204 222<br>0204 223<br>0204 223<br>0204 223 | 001C 211<br>001C 212 \$DEF DR_DDIBCNT .BLKL<br>0020 214<br>0020 215<br>0020 216<br>0020 216<br>0020 217<br>0020 218 .=^x200<br>0200 220 \$DEF DR_USER .BLKL<br>0204 221 .VIELD DR_USER.O.<-<br><gom><br/><gom><br/><gom><br/><gom><br/><gom><br/><gom><br/><gom><br/><gom></gom></gom></gom></gom></gom></gom></gom></gom> | 001C 211<br>001C 212 \$DEF DR_DDIBCNT .BLKL 1<br>0020 214<br>0020 215 .DEFINE USER CONTROL REGISTE<br>0020 216 .= x200<br>0200 219<br>0200 220 \$DEF DR_USER .BLKL 1<br>0204 221 .VIELD DR_USER.O<br>0204 221 .STELD OR USER.O<br>0204 222 .STELD OR USER.O<br>0204 223 .STELD OR USER.O<br>0206 .STELD OR USER.O<br>0207 .STELD OR USER.O<br>0208 .STELD OR USER.O<br>0209 .STELD OR USER.O | 001C 211<br>001C 212 \$DEF DR_DDIBCNT .BLKL 1 ; DDI<br>0020 214<br>0020 215<br>0020 216<br>0020 216<br>0020 217<br>00200 218 .= x200 ; STAN<br>0200 220 \$DEF DR_USER .BLKL 1 ; USEN<br>0204 221                                                                                                                                                   |

| - DR<br>DECL | 32 DRIVER<br>ARATIONS                                                                                                                                                                                                                                                |                                                                                          | K 15                                                                                                                                                           | 16-SEP<br>5-SEP                                                      | -1984<br>-1984                          | 00:21:10<br>00:20:00                                                                             | VAX/VMS Macro V04-00<br>[DRIVER.SRC]XFDRIVER.MAR;1                                                                                                                                                                                                                                                                                                                                                                           | Page | (2) |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|
| 00000400     | 0204 231<br>0400 233<br>0404 235<br>0404 235<br>0406 236<br>0410 237<br>0414 238<br>0416 240<br>0418 240<br>0418 240<br>0424 243<br>0424 243<br>0424 245<br>0424 245<br>0424 247<br>0424 248                                                                         | .=^X400<br>\$DEF<br>\$DEF<br>\$DEF<br>\$DEF<br>\$DEF<br>\$DEF<br>\$DEF<br>\$DEF<br>\$DEF | DR 780 DSL<br>DR 780 SBR<br>DR 780 GBR<br>DR 780 CMDBVA<br>DR 780 CMDLEN<br>DR 780 CMDSVAPT<br>DR 780 BFRBVA<br>DR 780 BFRLEN<br>DR 780 BFRSVAPT               | .BLKL<br>.BLKL<br>.BLKL<br>.BLKL<br>.BLKL<br>.BLKL<br>.BLKL<br>.BLKL | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | : STAR<br>: DR32<br>: SYST<br>: GLOE<br>: BASE<br>: LENG<br>: SVAR<br>: BASE<br>: LENG<br>: SVAR | RTS ON 3RD PAGE OF DR ADDRESS 2 STATUS LONGWORD TEM BASE REGISTER BAL PAGE TABLE BASE REGISTER E VIRTUAL ADDR. COMMAND BLOCK OFF OF COMMAND BLOCK PTE OF COMMAND BLOCK E VIRTUAL ADDR. BUFFER BLOCK TH OF BUFFER BLOCK OFF OF BUFFER BLOCK TO THE OFF BUFFER BLOCK TO THE DR. WCSA DR. WCSD REGISTER |      |     |
| 0000000      | 0424 249<br>0000 250<br>0000 251<br>0001 252<br>0002 253<br>0003 254<br>0004 255<br>0005 256<br>0006 257                                                                                                                                                             | .=0<br>SDEF<br>SDEF<br>SDEF<br>SDEF<br>SDEF<br>SDEF<br>SDEF<br>SDEF                      | DR 750 DSL<br>DR 750 SBR<br>DR 750 GBR<br>DR 750 CMDBVA<br>DR 750 CMDLEN<br>DR 750 CMDSVAPT<br>DR 750 BFRBVA<br>DR 750 BFRBVA<br>DR 750 BFRSVAPT<br>SDEFEND DR | .BLKB<br>.BLKB<br>.BLKB<br>.BLKB<br>.BLKB<br>.BLKB<br>.BLKB          | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | DR32<br>SYST<br>GLOE<br>BASE<br>LENG<br>SVAF<br>BASE<br>LENG                                     | RT OF LOCAL STORE REGISTERS  2 STATUS LONGWORD TEM BASE REGISTER BAL PAGE TABLE BASE REGISTER E VIRTUAL ADDR. COMMAND BLOCK GTH OF COMMAND BLOCK PTE OF COMMAND BLOCK E VIRTUAL ADDR. BUFFER BLOCK GTH OF BUFFER BLOCK PTE OF BUFFER BLOCK                                                                                                                                                                                   |      |     |
| 000000A0     | 0000 265<br>0000 265<br>0000 266<br>0000 267<br>0000 268<br>0000 270<br>00A0 271<br>00A0 273<br>00A0 273<br>00A0 275<br>00A0 275<br>00A0 276<br>00A0 277<br>00A0 278<br>00A0 278<br>00A0 278<br>00A0 278<br>00A0 283<br>00AC 283<br>00AC 285<br>00AC 285<br>00O0 287 | DR32                                                                                     | SPECIFIC UCB OFFS  SDEFINI UCB  DPC+4  _VIELD UCB,0,<-                                                                                                         |                                                                      |                                         | DEFI<br>ADA<br>FOR<br>ABO                                                                        | INE BITS FOR UCBSW_DEVSTS APTER POWER UP RK INTERLOCK BIT DRT PENDING DICATES DEVICE IS DR750                                                                                                                                                                                                                                                                                                                                |      |     |
| 000000AC     | 00A0 278<br>00A0 279<br>00A4 280<br>00A8 281<br>00AC 282<br>00AC 283<br>00AC 284<br>00AC 285<br>00AC 285<br>00AC 285                                                                                                                                                 | SDEF<br>SDEF<br>SDEF<br>UCBSK_S                                                          | UCB\$L_DCR<br>UCB\$L_SAVSTATUS<br>UCB\$L_SAVDCR                                                                                                                | .BLKL                                                                | 1                                       | STOR                                                                                             | RED COPY OF DCR REGISTER ED STATUS FOR DRIVER ABORTS ED COPY OF DCR REGISTER                                                                                                                                                                                                                                                                                                                                                 |      |     |

X

XFDRIVER VO4-000

STARTDATAP>

FUNCTAB LOAD MICROCODE, <LOADMCODE> FUNCTAB STARTDATA\_FDT, <STARTDATA,-

**FUNCTAB** 

: NO BUFFERED I/O FUNCTIONS : LOAD MICROCODE : START DATA XFDRIVER VO4-000 - DR32 DRIVER DECLARATIONS

0054 345 0060 346 M 15

16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1

STARTDATAP>

: START DATA PHYSICAL

Page

(2)

50

60

```
- DR32 DRIVER
LOAD_MICROCODE - Load microcode FDT rout 5-SEP-1984 00:21:10
                                                                                               VAX/VMS Macro V04-00
[DRIVER.SRC]XFDRIVER.MAR; 1
                                                                                                                                          Page
                                     .SBTTL LOAD_MICROCODE - Load microcode FDT routine
       FUNCTIONAL DESCRIPTION:
                                    This routine is an fDT routine which performs the Load Microcode QIO. It locks the microcode image in memory, verifies that the device is not busy, loads and then verifies the microcode. Verification consists of addressing all the locations in the WCS and checking for a parity error.

If the microcode is loaded successfully, the the WCS valid bit
                                     is set in the DR32.
                                     This routine also sets the data rate to the last value stored
                  360
361
362
363
364
366
367
368
370
                                     in the device dependent characteristics.
                           CALLING SEQUENCE:
                                     Called from the FDT routine dispatcher in the Q10 system service.
                                    On completion jumps to EXESFINISHIOC.
                           INPUT PARAMETERS:
                                     R3
R4
R5
                                                 Address of I/O packet.
                                                 Current process PCB address.
                                                Address of UCB.
Address of CCB.
Address of microcode image.
                                     P2(AP)
                                                Size (in bytes) of microcode image.
                           IMPLICIT INPUTS:
                                    NONE
                           OUTPUT PARAMETERS:
                                                Contains a completion code
                           IMPLICIT OUTPUTS:
                                    The WCS valid bit is set in the DR32.
                           COMPLETION CODES:
                                    These are in addition to the ones EXESWRITELOCK can return:
                                    SSS_NORMAL
SSS_PARITY
                                                             Successful completion
                                                             Parity error detected during microcode verification 
Device is active
                  394
395
396
397
398
400
401
402
403
                                    SS$ DEVACTIVE
SS$ POWERFAIL
       0060
0060
0060
0060
0060
0060
0060
                                                             Device is powered down
                           SIDE EFFECTS:
                                     None
                        LOAD_MICROCODE:
```

: Get address of microcode image

P1(AP),R0

MOVL

(3)

N 15

|                                                  | - DR3                      | 2 DRIVER<br>MICROCODE - Load                                                                                                                 | B 16<br>16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 Page<br>microcode FDT rout 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1                                                                                                                                         | 10 |
|--------------------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 51 04 A0<br>00000000 ° GF<br>64 A5 20            | 3C<br>7D<br>16             | 0063 405<br>0067 406<br>006A 407                                                                                                             | MOVZWL P2(AP),R1 ; Get size of image (in bytes) MOVQ R0,R9 ; Save address and size in R9 and R10 JSB G^EXE\$WRITELOCK ; Lock image into memory BICW #UCB\$M_POWER,UCB\$W_STS(R5) ; Clear powerfail bit                                                              |    |
|                                                  |                            | 0070 408<br>0074 409<br>0074 410<br>0074 411                                                                                                 | ASSUME IDB\$L_CSR EQ 0                                                                                                                                                                                                                                              |    |
| 54 24 A5<br>54 20 B4                             | D0                         | 0074 412<br>0078 413                                                                                                                         | MOVL UCB\$L_CRB(R5),R4; Get pointer to CRB MOVL aCRB\$E_INTD+VEC\$L_IDB(R4),R4; Get address of 1st device CSR                                                                                                                                                       |    |
|                                                  |                            | 007C 414<br>007C 415 10\$:<br>007C 416<br>007C 417                                                                                           | ; R4 contains address of 1st device CSR. Make sure device has ; power before accessing any device registers. Then, if the device ; is not busy, reset it and clear WCS valid.                                                                                       |    |
|                                                  |                            | 007C 418<br>007C 419                                                                                                                         | ASSUME UCB_V_ADPPWRUP EQ 0                                                                                                                                                                                                                                          |    |
| 50 0364 8F                                       | 3C<br>E9                   | 007C 420<br>007C 421<br>0081 422                                                                                                             | MOVZWL #SS\$ POWERFAIL.RO ; Assume error BLBC UCB\$0_DEVSTS(R5),15\$ ; Branch if adapter has no power                                                                                                                                                               |    |
| 50 0204 86                                       | 30                         | 0085 423<br>0085 424<br>008A 425                                                                                                             | MOVZWL #SS\$ DEVACTIVE.RO ; Assume device is active DSBINT UCB\$B FIPL(R5) ; Raise IPL to fork level                                                                                                                                                                |    |
| 03 64 A5 08<br>00A7<br>64 4000 8F<br>00000800 8F | 31<br>30                   | 007C 420<br>007C 421<br>0081 422<br>0085 423<br>0085 424<br>008A 425<br>0091 426<br>0096 427 15\$:<br>0099 428 17\$:<br>009E 429<br>00A4 430 | BBC #UCB\$V_BSY,UCB\$W_STS(R5),17\$; Br. if UCB is not busy BRW 80\$; Finish I/O MOV7WI #DCP K RESET DR DCP(R4); Reset DR32                                                                                                                                         |    |
| 04 A4                                            |                            | 00A4 430<br>00A6 431                                                                                                                         | BICL #DR OTE M VALID, - ; Clear WCS valid bit DR_OTL(R4) ENBINT ; Lower IPL                                                                                                                                                                                         |    |
|                                                  |                            | 00A9 432<br>00A9 433                                                                                                                         | ; Load last data rate saved in device dependent characteristics.                                                                                                                                                                                                    |    |
| 50 04 A4<br>50 44 A5<br>04 A4 50                 | 90                         | 00A6 431<br>00A9 432<br>00A9 433<br>00A9 434<br>00A9 435<br>00AD 436<br>00B1 437<br>00B5 438<br>00B5 439                                     | MOVL DR_UTL(R4),R0 ; Get contents of Utility reg. MOVB UCB\$L_DEVDEPEND(R5),R0 ; Load data rate MOVL R0,DR_UTL(R4) ; Put back into Utility reg.                                                                                                                     |    |
|                                                  |                            | 0085 438<br>0085 439<br>0085 440<br>0085 441<br>0085 442<br>0085 443                                                                         | ; Set up to load microcode. RO will contain address of microcode image. R1 will contain size of image in bytes. Convert this to number of WCS words by dividing by 5 (each WCS word contains 5 bytes). R2 will be used to contain WES address.                      | ,  |
|                                                  |                            | 00B5 444                                                                                                                                     | ASSUME DR WCSA_V_SEL EQ 0 ASSUME DR WCSA_V_ADDR EQ 1                                                                                                                                                                                                                |    |
| 50 59<br>51 05                                   | 7D<br>C6<br>13             | 0085 446<br>0085 447<br>0088 448<br>0088 449                                                                                                 | MOVQ R9,R0 ; Restore address and size in R0 and R1 DIVL #5,R1 ; Convert bytes to number of WCS words. BEQL 40\$ ; Load zero words                                                                                                                                   |    |
| 50 59<br>51 05<br>71<br>51 02<br>58 51           | C6<br>13<br>D7<br>C4<br>D0 | 0085 445<br>0085 446<br>0085 447<br>0088 448<br>0088 449<br>008D 450<br>008F 451<br>00C2 452<br>00C5 453<br>00C7 454                         | DECL R1  MULL #2,R1  MOVL R1,R11  CLRL R2  COnvert to address of highest word  Account for address being incr. by 2  Save number of WCS words  Start loading at zero                                                                                                |    |
|                                                  |                            | 00C7 455 20\$:<br>00C7 456<br>00C7 457<br>00C7 458<br>00C7 459                                                                               | Load next WCS word. Each word gets loaded in two parts. First four bytes get loaded and then one byte gets loaded. On the DR750, it is necessary to set the WCS flag bit to distinguish between accessing WCS and local store. This bit has no effect on the DR780. |    |
| 80000000 86                                      | <b>C9</b>                  | 0007 460<br>0007 461                                                                                                                         | BISL3 #DR_WCSA_M_WCS,- ; Load WCS address                                                                                                                                                                                                                           |    |

B 16

| XFDRIVER<br>V04-000 |                                                      | - DR32 DRIVER<br>LOAD_MICROCODE - Load mid           | C 16<br>16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 Page<br>crocode FDT rout 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1                                           |
|---------------------|------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 08 A4               | 08 A4 52<br>0C A4 80<br>52 80000001 8F               | 00CD 462<br>00 00D0 463<br>C9 00D4 464<br>00DD 465   | R2.DR_WCSA(R4)  MOVL (R0)+,DR_WCSD(R4) ; Load four bytes  BISL3 #DR_WCSA_M_WCS!- ; Load WCS address and set SELECT bit                                              |
|                     | FFE0 52 02 51                                        | 9A 000D 466<br>F1 00E1 467<br>00E7 468               | BISL3 #DR_WCSA_M_WCS!- Load WCS address and set SELECT bit DR_WCSA_M_SEL,R2.DR_WCSA(R4)  MOVZBL (R07+,DR_WCSD(R4) Load one byte ACBL R1,#2,R2,20\$ Repeat load loop |
|                     |                                                      | 00E7 469                                             | ; Verify WCS by addressing each word (look for parity error later).                                                                                                 |
|                     |                                                      | 00E7 472<br>00E7 473                                 | ASSUME DR_DCR EQ 0<br>ASSUME DR_UTL EQ DR_DCR+4<br>ASSUME DR_UTL_M_PARERR EQ DR_DCR_M_PARERR                                                                        |
|                     | 50 54                                                | DO 00E7 474<br>DO 00E7 475<br>00EA 476               | MOVL R4,R0 ; Get address of DR750's register with                                                                                                                   |
|                     | 03 68 A5 03<br>50 04                                 | EQ QQEA 477                                          | BBS #UCB_v_DR750,UCB\$w_DEVSTS(R5),22\$ : Branch if DR750 ADDL #4,R0 : Get_address of DR780's register with                                                         |
|                     | 60 80000000 8F<br>52<br>80000000 8F                  | C8 00F2 480 22\$: E                                  | parity error bit (DR_UTL)  BISL #DR_UTL_M_PARERR,(RO) : Clear parity error  CLRL R2 : Clear WCS address  BISL3 #DR_WCSA_M_WCS,- : Load WCS address                  |
|                     | 80000000 8F<br>08 A4 52<br>51 0C A4<br>FFED 52 02 5B | DO 0104 484                                          | R2, DR W(SA(R4))  MOVL DR W(SD(R4), R1 ; This allowes parity errors to be seen  ACBL R1T,#2,R2,25\$ ; Repeat verify loop                                            |
|                     |                                                      | 010E 486<br>010E 487                                 | Reload if a powerfail occurred while loading.                                                                                                                       |
|                     | 06 64 A5 05<br>FF5D                                  | E5 0114 490 E                                        | Raise IPL to lockout powerfail BBCC #UCB\$V_POWER,UCB\$W_STS(R5),30\$; Branch if no powefail ENBINT ; Powerfail occurred; lower IPL and BRW 10\$; retry             |
|                     |                                                      | 011F 494                                             | ASSUME DR_UTL_V_PARERR EQ 31                                                                                                                                        |
| 0                   | 60<br>15<br>04 A4 00000800 8F                        | 05 011F 496 30\$: 1<br>19 0121 497<br>C8 0123 498    | STL (RO) ; No powerfail - Test for parity error BLSS 60\$ BISL #DR_UTL_M_VALID,DR_UTL(R4) ; Set WCS valid ENBINT ; Lower IPL                                        |
|                     | 64 0600 8F<br>50 01<br>08                            | 0138 504                                             | MOVZWL #DCR_K_SETINTENB,DR_DCR(R4) ; Set interrupt enable MOVZWL #SS\$_NORMAL,R0 ; Return success status BRB 80\$; Return to user                                   |
|                     |                                                      | 0138 505<br>0138 506 60\$: ;<br>0138 507<br>0138 508 | ; ERROR - Parity error during WCS verification                                                                                                                      |
|                     | 50 01F4 8F                                           | 3C 013B 509 P                                        | ENBINT : Lower IPL Completion code : Completion code                                                                                                                |
|                     |                                                      | 0140 511<br>0140 512 80\$:                           | Common return                                                                                                                                                       |
|                     | 00000000°GF                                          | 17 0140 513<br>17 0140 514                           | JMP G^EXESFINISHIOC ; Finish 1/0                                                                                                                                    |

D 16 - DR32 DRIVER STARTDATA\_FDT - Start Data FDT routine

16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR:1

.SBTTL STARTDATA\_FDT - Start Data FDT routine

#### FUNCTIONAL DESCRIPTION:

This routine is the Start Data QIO FDT routine. After it does some error checking on the user's command table, it allocates an I/O Request Packet Extension (IRPE) and links it onto the IRP. Then the user's command block and buffer block are locked into memory, with the context for these regions stored in the IRPE. Finally, the address of the DR32's go bit is returned to the user and the IRP is queued to the driver.

# CALLING SEQUENCE:

Called from the FDT routine dispatcher in the QIO system service. On completion, jumps to either EXE\$QIODRVPKT (on success), EXE\$FINISHIOC (on errors that complete the I/O), or EXE\$ABORTIO (on errors that abort the I/O).

#### INPUT PARAMETERS:

R3 R4 R5 Address of IRP Current process PCB address Address of UCB Address of CCB

P1(AP) P2(AP) Address of command table Size (in bytes) of command table (must be XF\$K\_CMT\_LENGTH)

#### IMPLICIT INPUTS:

The format of the command table is:

| - | 1 | (A | P) | -> |
|---|---|----|----|----|
|   |   |    |    |    |

| <b>+</b>                                            |                                   |
|-----------------------------------------------------|-----------------------------------|
| Size of command block (in bytes)                    | XF\$L_CMT_CBLKSZ                  |
| Address of Command block (Must be quadword aligned) | XF\$L_CMT_CBLKAD                  |
| Size of buffer block (in bytes)                     | XF\$L_CMT_BBLKSZ                  |
| Address of buffer block                             | XF\$L_CMT_BBLKAD                  |
| Address of Packet AST routine                       | XF\$L_CMT_PASTAD                  |
| Packet AST parameter                                | XF\$L_CMT_PASTPM                  |
| Flags   Data   Rate                                 | XF\$B_CMT_RATE<br>XF\$B_CMT_FLAGS |
| Address of longword to receive address of GO bit    | XF\$L_CMT_GBITAD                  |

address is accessible.

FINISH 10

BEQL

CMPL

BGEQU

TSTL

XF\$L\_CMT\_CBLKSZ(SP) FINISH\_IO

XFSL\_CMT\_BBLKSZ(SP)

XF\$L CMT CBLKSZ(SP),-#^X20000000 Is command block size zero?

Is buffer block size zero?

Is command block greater than or equal to 2\*\*29?

Yes, finish 1/0

Yes, finish I/O

D5 13 D1

1E D5

20000000

08

AE

| XFDRIVER<br>VO4-000 |                                                                                                          | - DR32 DRIVER<br>STARTDATA_FDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F 16<br>Start Data FDT routine                                                                                                              | 16-SEP-1984 00:21:10<br>5-SEP-1984 00:20:00                                                                 | VAX/VMS Macro V04-00 Page 14<br>[DRIVER.SRC]XFDRIVER.MAR;1 (4)                                                                                                                                                                                                                         |
|---------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | 200000000 8F<br>200000000 8F<br>1B<br>5B 0324 8F<br>04 AE 07                                             | 13 0175 63<br>01 0177 63<br>017A 63<br>1E 017F 63<br>3C 0181 63<br>0186 63<br>12 018A 63<br>018C 63<br>0193 64<br>0193 64<br>0193 64                                                                                                                                                                                                                                                                                                                                                                 | BEQL FINISH I CMPL XF\$L CMT  #^X20000 BGEQU FINISH I MOVZWL #\$S\$ BUF BITL #7,XF\$L BNEQ FINISH I IFWRT #4,0XF\$L ALL_OK                  | O Yes BBLKSZ(SP),- Is 000 equi O Yes NOTALIGN,R11 Char CMT_CBLKAD(SP) Is O No, _CMT_GBITAD(SP),- Br ; addi  | finish I/O buffer block greater than or al to 2**29? , finish I/O nge completion code in R11 command block quadword aligned?   finish I/O . if location to store GO bit ress is writeable                                                                                              |
|                     | 50 OC                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | MOVZWL #SS\$_ACC                                                                                                                            | V10,R0 ; Sto                                                                                                | re completion code                                                                                                                                                                                                                                                                     |
|                     |                                                                                                          | 0196 64<br>0196 64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ABORT_10: ; Come here                                                                                                                       | with completion code                                                                                        | in RO                                                                                                                                                                                                                                                                                  |
|                     | 00000000 GF                                                                                              | 0196 64<br>0196 64<br>17 0196 64<br>0190 65                                                                                                                                                                                                                                                                                                                                                                                                                                                          | JMP G^EXESAB                                                                                                                                | ORTIO ; Abo                                                                                                 | rt I/0                                                                                                                                                                                                                                                                                 |
|                     |                                                                                                          | 0196 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | FINISH_10: ; Come here                                                                                                                      | with completion code                                                                                        | in R11                                                                                                                                                                                                                                                                                 |
|                     | 00000000°GF                                                                                              | 0193 64<br>0196 64<br>0196 64<br>0196 64<br>0196 64<br>0190 65<br>0190 65<br>0190 65<br>0190 65<br>0190 65<br>0190 65<br>0190 65<br>0190 65<br>0190 65<br>0190 65                                                                                                                                                                                                                                                                                                                                    | MOVL R11,R0<br>JMP G^EXESFI                                                                                                                 | NISHIOC ; Fin                                                                                               | e completion code<br>ish I/O                                                                                                                                                                                                                                                           |
|                     |                                                                                                          | 01A5 65<br>01A5 65<br>01A5 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ALL_OK: Everything che the IRP.                                                                                                             | cks out. Allocate an                                                                                        | IRPE and link it to                                                                                                                                                                                                                                                                    |
|                     | 00000000 'GF<br>53<br>E3 50<br>0A A2 2C<br>54 A3 52<br>2A A3 0800 8F<br>2A A2<br>2C A2<br>38 A2<br>5A 52 | 01A5 65 DD 01A5 66 16 01A7 66 8ED0 01AD 66 E9 01B0 66 90 01B3 66 D0 01B7 66 A8 01BB 66 B4 01C1 66 D4 01CA 67 01CD 67 | PUSHL R3 JSB G^EXESAL POPL R3 BLBC R0,ABORT MOVB #DYNSC I MOVL R2,IRPSL BISW #IRPSM E CLRW IRPESW S CLRL IRPESL S CLRL IRPESL S MOVL R2,R10 | IO RPE,IRPE\$B_TYPE(R2) EXTEND(R3); Lin XTEND,IRP\$W_STS(R3) TS(R2); Clei VAPTE1(R2); Clei VAPTE2(R2); Clei | e address of IRP ccate an IRPE (returns addr. in R2) tore address of IRP led do to insufficient memory ; Change type from IRP to IRPE k IRPE onto IRP ; Set extend bit in status word ar status bits in IRPE ar SVAPIE for region 1 ar SVAPIE for region 2 m now on R10 points to IRPE |
|                     |                                                                                                          | 01CD 67<br>01CD 67<br>01CD 67                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ; Now lock comma<br>; the context (S<br>; IRP, SP points                                                                                    | nd block and buffer b<br>VAPTE, BCNT, and BOFF:<br>to the command table                                     | lock into memory, saving ) in the IRPE. R3 points to the , and R10 points to the IRPE.                                                                                                                                                                                                 |
|                     |                                                                                                          | 01CD 67                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ASSUME IRPESU_B                                                                                                                             | OFF1 EQ IRPEST SVAP                                                                                         |                                                                                                                                                                                                                                                                                        |
|                     | 51 8E<br>50 8E<br>34 AA 51<br>44 AA 50<br>38<br>2C A3<br>2C AA                                           | 01CD 67<br>01CD 68<br>00 01D3 68<br>00 01D7 68<br>7D 01DB 68<br>7D 01DD 68                                                                                                                                                                                                                                                                                                             | MOVL (SP)+,R1 MOVL (SP)+,R0 MOVL R1,IRPES MOVL R0,IRPES BSBB LOCK BFR MOVQ IRPSC SV                                                         | L_BCNT1(R10)                                                                                                | length of command block address of command block re length of command block in IRPE re address of command block in IRPE k command block into memory re SVAPIE and BOFF in IRPE                                                                                                         |
|                     | 51 8E                                                                                                    | DO 01E2 68                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | MOVL (SP)+,R1                                                                                                                               | VAPTE1(R10) ; Get                                                                                           | length of buffer block                                                                                                                                                                                                                                                                 |
|                     |                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                             |                                                                                                             |                                                                                                                                                                                                                                                                                        |

|                        |                                  |                            | - DR<br>STAR         | 32 DRI                                               | VER<br>FDT - Star                                                                                                                               | rt Data FDT                          | G 16 routine                                                                 | 16-SEP-1984 0<br>5-SEP-1984 0                        | 00:21: | 10 VAX/VMS Macro V04-00<br>00 [DRIVER.SRC]XFDRIVER.MAR;1                                                                                                  | Pag       |
|------------------------|----------------------------------|----------------------------|----------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| 40                     | 50<br>AA<br>AA<br>2C<br>38<br>2C | 8E<br>50<br>23<br>AA<br>A3 | DO<br>DO<br>10<br>7D | 01E5<br>01E8<br>01EC<br>01F0<br>01F2<br>01F5<br>01F7 | 687<br>688<br>689<br>690<br>691<br>692<br>693<br>694<br>695<br>696<br>698<br>699<br>700<br>701<br>702<br>703<br>704<br>705<br>706<br>707<br>708 | MOVL<br>MOVL<br>BSBB<br>MOVQ<br>CLRQ | (SP)+,RO<br>R1,IRPE\$L<br>R0,IRPE\$L<br>LOCK BFR<br>IRP\$C SVA<br>IRP\$C SVA | BCNT2(R10) BBLKADR(R10) PTE(R3) - APTE2(R10) PTE(R3) |        | set address of buffer block tore length of buffer block in I store addr. of buffer block in IR ock buffer block into memory store SVAPTE and BOFF in IRPE | RPE<br>PE |
|                        |                                  |                            |                      | 01FA<br>01FA<br>01FA<br>01FA<br>01FA                 | 695<br>696<br>697<br>698<br>699                                                                                                                 | ; Now of return ASSUME ASSUME        |                                                                              | ASTPRM EQ IRP                                        |        | CTASTADR+4                                                                                                                                                |           |
| 40                     | A3                               | 8E                         | 70                   | 01FA                                                 | 701                                                                                                                                             | MOVQ                                 | (SP)+,IRP                                                                    | \$L_PKTASTADRO                                       | (R3)   | Store packet AST address and                                                                                                                              |           |
| 3C<br>51<br>0000<br>9E | A3<br>24<br>00200<br>20          | 8E<br>A5<br>8F<br>B1       | DO<br>DO<br>C1       | 01FE<br>01FE<br>0202<br>0206<br>020C<br>020F         | 703<br>704<br>705<br>706                                                                                                                        | MOVL<br>MOVL<br>ADDL3                | (SP)+,IRP<br>UCB\$L_CRB<br>#DR_USER,<br>aCRB\$L_IN                           | \$B_RATE(R3)<br>(R5),R1<br>TD+VEC\$L_IDB(            | (R1),  | Store packet AST address and parameter in IRP Store data rate and flags in IRP Set address of CRB in RT Store address of GO bit a(SP)+                    |           |
| 0000                   | 00000                            | 'GF                        | 17                   | 020F                                                 | 708                                                                                                                                             | JMP                                  | G*EXE\$010                                                                   | DRVPKT                                               | ; 6    | Queue packet to driver                                                                                                                                    |           |

G 16

- DR32 DRIVER

LOCK\_BFR - Lock a buffer into memory

VAX/VMS Macro V04-00 [DRIVER.SRC]XFDRIVER.MAR; 1

.SBTTL LOCK\_BFR - Lock a buffer into memory

## FUNCTIONAL DESCRIPTION:

This routine is called from the Start Data FDT routine to lock the command block and the buffer block into memory. If either lock fails, this routine unlocks any locked memory and deallocates the IRPE before during a coroutine return to EXESMODIFYLOCKR.

#### CALLING SEQUENCE:

BSBB LOCK\_BFR

Note that if the lock fails, this routine returns to EXESMODIFYLOCKR, not the caller.

#### INPUT PARAMETERS:

Address of buffer to lock Length of buffer (in bytes) R1 R3

Address of IRP

H 16

Current process PCB address

R4 R5 Address of UCB Address of CCB R6 R10 Address of IRPE

#### IMPLICIT INPUTS:

Offsets IRPE\$L\_SVAPTE1, IRPE\$W\_BOFF1, and IRPE\$L\_BCNT1 in the IRPE describe the previously locked area.

#### **OUTPUT PARAMETERS:**

None (returning to the caller implies success)

#### IMPLICIT OUTPUTS:

Offsets IRP\$L\_SVAPTE and IRP\$W\_BOFF in the IRP describe the syapte and the byte offset of the locked area.

#### COMPLETION CODES:

None

## SIDE EFFECTS:

As previously mentioned, on a lock failure the previously locked area is unlocked, the IRPE is deallocated, and the I/O is either completely backed up or aborted.

## LOCK\_BFR:

766

G^EXESMODIFYLOCKR JSB BLBS RO.90\$

; Lock buffer into memory ; Success!!!

; Got a lock failure. Unlock previously locked area if there is one.

PUSHR #^M<RO,R1,R2,R3> : Save registers

00000000°GF 35 50

OF 88 XFDRIVER VO4-000

00A0 C5

```
16-SEP-1984 00:21:10
5-SEP-1984 00:20:00
                                                                                      VAX/VMS Macro V04-00
[DRIVER.SRC]XFDRIVER.MAR:1
STARTIO - Entry point to start 1/0
                                 .SBTTL STARTIO - Entry point to start I/O
                790
791
792
793
794
795
796
797
798
800
801
                      : FUNCTIONAL DESCRIPTION:
                                 This routine actually starts the DR32. It loads the required DR32 registers and clears the halt bit.
                        CALLING SEQUENCE:
                                 Jumped to through the driver dispatch table by IOCSINITIATE
                        INPUT PARAMETERS:
                                            Address of the IRP
Address of the UCB
                 804
                        IMPLICIT INPUTS:
                 805
                                 Various fields in the IRP, IRPE, and UCB. In particular note that offset UCB$L_IRP in the UCB contains the address of the IRP.
                808
809
                        OUTPUT PARAMETERS:
                                 None
                        IMPLICIT OUTPUTS:
                                 None
                        COMPLETION CODES:
                                 Returned to REQ_COMPLETE:
                                 SS$ POWERFAIL
                                                       Adapter has no power
                                 SS$ MCNOTVALID
                                                       Microcode is not valid
                                 SS$ BADPARAM
                                                       Specified data rate is too large
                        SIDE EFFECTS:
                                 None
                     STARTIO:
                                   Get address of first CSR into R4. Make sure adapter has power and
                                 ; then clear abort bit and parity error bit.
                                 ASSUME IDB$L_CSR EQ 0
ASSUME UCB_V_ASPPWRUP EQ 0
                                           UCB%L CRB(R5),R1

aCRB$C INTD+VEC$L IDB(R1),R4

UCB$W_DEVSTS(R5),5$
                                                                                           Get address of CRB
Get address of first CSR
                                 MOVL
 DO E8
                                 MOVL
                                                                                           Branch if adapter has power
                                 BLBS
                                                                                           Adapter has no power
Clear abort interrupt bit
                                            408
                                 BRW
                                            #DCR K CLRABTINT, DR DCR(R4)
#DR DCR M DCRABT, UCB$L DCR(R5)
#DR_UTL_M_PARERR, DR_UTE(R4)
                                 MOVZWL
                                                                                           Clear abort bit in DCR in UCB
                                 BICL
                                 BISL
                                                                                        : Clear parity error bit (DR780)
```

J 16

- DR32 DRIVER

|          |                                    |                                                  |                                              | - DR                                               | 32 DR1                                                                               | VER<br>Entry                                                     | point              | to start                                                    | K 16                                                                        | 16-SEP                                                                                     | -1984 (<br>-1984 (                                                         | 00:21:                                                   | 10 y                                                             | X/VMS<br>DRIVER.                                                               | Macro V<br>SRC]XFD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 04-00<br>RIVER.MAI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R; 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Page                                      | 19 (6) |
|----------|------------------------------------|--------------------------------------------------|----------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------|--------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------|
| 64       | 8008                               | 00000                                            | 8F                                           | 83                                                 | 0279                                                                                 | 844                                                              |                    | BISL                                                        | #DR_DCF                                                                     | M_PARERI                                                                                   |                                                                            |                                                          |                                                                  | Clear                                                                          | parity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | error b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | it ([                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R750)                                     |        |
|          |                                    |                                                  |                                              |                                                    | 0280                                                                                 | 846                                                              |                    | ; Load                                                      | Utility                                                                     | register                                                                                   | with d                                                                     | data r                                                   | ate a                                                            | nd pari                                                                        | ty erro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | r abort 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | oit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                           |        |
|          |                                    |                                                  |                                              |                                                    | 0280                                                                                 | 848                                                              |                    | ASSUME                                                      | XF\$V_CF                                                                    | AT_SETRTE                                                                                  | £0 0                                                                       | )                                                        |                                                                  |                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |        |
| 50<br>64 | 080                                | 04<br>00000<br>00000<br>28 3D<br>30              |                                              | DO<br>CA<br>CA<br>E9                               | 0280<br>0284<br>028B<br>0292<br>0296<br>0299                                         | 850<br>851<br>852<br>853<br>854                                  |                    | MOVL<br>BICL<br>BICL<br>BLBC<br>CMPB                        | #DR_UTL<br>#DR_DCF<br>IRP\$B_F<br>IRP\$B_F<br>G^10C\$6                      | (R4) RO<br>_M_ENPEAL<br>FLAGS(R3)<br>RATE(R3).                                             | B,RO<br>B,DR_DO<br>,10\$                                                   | R (R4)                                                   | ranch<br>ompare                                                  | nable<br>ar ena<br>if we<br>speci<br>by SY                                     | par. er<br>ble par<br>shouldn<br>fied ra<br>SGEN pa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | lity reg<br>r. abort<br>err. al<br>t set ra<br>te with a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ister<br>bit<br>bort<br>bte<br>maxim                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | (DR78)<br>(DR75)                          | 0)     |
|          | 04 68<br>51<br>51                  | FC<br>3C                                         | 13<br>8F<br>03<br>8F<br>A3                   | 1A<br>9A<br>E1<br>9A<br>91<br>1B<br>31<br>90<br>90 | 029E<br>02A0<br>02A4<br>02A9<br>02AD<br>02B1                                         | 856<br>857<br>858<br>859<br>860<br>861                           | 73:                | BGTRU<br>MOVZBL<br>BBC<br>MOVZBL<br>CMPB<br>BLEQU           | #DR780<br>#UCB V<br>#DR750<br>IRP\$B_F                                      | MAXRATE , I<br>DR750 , UCI<br>MAXRATE , I<br>ATE (R3) , I                                  |                                                                            | VSTS (R                                                  | et had<br>5),7\$<br>et had<br>ompare<br>llowed                   | dware; Bra<br>dware<br>speci                                                   | maximum<br>nch if<br>maximum<br>tied ra<br>rdware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | clock range of the with a modern branch of the with a modern branch of the with a modern branch of the without the with a modern branch of the without | ete (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (DR780<br>(DR750                          |        |
|          | 50<br>44                           | A5 3C                                            | A3<br>50<br>01<br>A3                         |                                                    | 02AD<br>02B1<br>02B3<br>02B6<br>02BA<br>02BE                                         | 861<br>862<br>863<br>864<br>865                                  | 85:<br>95:<br>105: | BRW<br>MOVB<br>MOVB<br>BBS                                  | 60\$ IRP\$B F RO,UCB\$ #XF\$V (                                             | RATE(R3), I<br>BL DEVDEPI<br>CMT DIPEAL                                                    | RO<br>END (R5)<br>B -<br>50\$                                              | RSP                                                      | et rai                                                           | oo high<br>te<br>te into<br>if we                                              | - erro<br>device<br>shouldn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | r<br>characte<br>'t set al                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | erisi<br>bort                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | tics                                      |        |
| 50<br>64 | 080                                | 00000                                            | 8F<br>8F<br>50                               | C8<br>C8<br>D0                                     | 02C0<br>02C3<br>02CA<br>02D1<br>02D5                                                 | 866<br>867<br>868<br>869<br>870                                  | 20\$:              | BISL<br>BISL<br>MOVL                                        | #DR_UTL<br>#DR_DCF<br>RO, DR_L                                              | RATE(R3), I<br>BL DEVDEPI<br>CMT DIPEAL<br>FLAGS(R3)<br>_ M_ENPEAL<br>CMTENPEAL<br>JTL(R4) | B.RO<br>B.DR_D(                                                            | R (R4)                                                   | et abo                                                           | ort on<br>et abor<br>tility                                                    | parity<br>t on pa<br>registe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | error bi<br>r. err.  <br>r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | t (DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R780)<br>(DR750                           | )      |
|          |                                    |                                                  |                                              |                                                    | 02D5<br>02D5<br>02D5<br>02D5<br>02D5                                                 | 871<br>872<br>873<br>874<br>875                                  |                    | ; Load<br>; Note<br>; the I<br>; into                       | up the r<br>that the<br>DR750 reg<br>the DR_                                | rest of the DR780 registers and DCSA regis                                                 | he DR32<br>egister<br>re acce<br>ster ar                                   | regins are essed and read                                | sters<br>directly<br>by loading                                  | tly ad<br>ading t                                                              | dressab<br>he regi<br>ing the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | le while<br>ster numi<br>DR_WCSD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ister.                                    |        |
|          | 29 68                              | A5 54                                            | A3<br>03                                     | D0<br>E0                                           | 02D5<br>02D9<br>02DE                                                                 | 876<br>877<br>878                                                |                    | MOVL<br>BBS                                                 | #UCB_V_                                                                     | XTEND(R3)<br>DR750,UC                                                                      | R2<br>B\$W_DEV                                                             | STS (R                                                   | 2 poi:<br>5),30                                                  | its to                                                                         | IRPE<br>anch if                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DR750                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |        |
|          |                                    |                                                  |                                              |                                                    | 02DE                                                                                 | 879<br>880                                                       |                    |                                                             | DR780 re                                                                    |                                                                                            |                                                                            |                                                          |                                                                  |                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |        |
|          | 51                                 | 0404                                             | <b>C4</b>                                    | DE                                                 | 02DE                                                                                 | 881<br>882                                                       |                    | MOVAL                                                       | DR_780_                                                                     | SBR(R4),I                                                                                  | 81                                                                         | ; R                                                      | 1 will                                                           | step                                                                           | through                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                           |        |
| 81       | 0000<br>81<br>81<br>81<br>81<br>81 | 81<br>00000°<br>44<br>34<br>20<br>48<br>40<br>38 | 0C<br>GF<br>A2<br>A2<br>A2<br>A2<br>A2<br>A2 | D8<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0             | 02DE<br>02DE<br>02DE<br>02E3<br>02E3<br>02E5<br>02ED<br>02F1<br>02F5<br>02FD<br>0305 | 879<br>8881<br>8881<br>8881<br>8881<br>8881<br>8881<br>8881<br>8 |                    | MFPR<br>MOVL<br>MOVL<br>MOVL<br>MOVL<br>MOVL<br>MOVL<br>BRB | WPR\$ SE<br>G^MMG\$6<br>IRPE\$L<br>IRPE\$L<br>IRPE\$L<br>IRPE\$L<br>IRPE\$L | GR, (R1) + GL GPTBASI CBLKADR(I BCNT1 (R2) SVAPTE1 (I BBLKADR(I BCNT2 (R2) SVAPTE2 (I      | E (R1) 4<br>R2) (R1)<br>(R1) 4<br>R2) (R1<br>R2) (R1)<br>(R1) 4<br>R2) (R1 | DI<br>DI<br>DI<br>DI<br>DI<br>DI<br>DI<br>DI<br>DI<br>DI | R_SBR<br>R_GBR<br>R_CMDE<br>R_CMDE<br>R_GMDE<br>R_BFRE<br>R_BFRE | = cont<br>= addr<br>DVA = a<br>EN = L<br>DVAPTE<br>BVA = a<br>EN = L<br>DVAPTE | ents of ess of ddress ength o essential ddress ength o essential e | sys. bas<br>global pa<br>of command<br>f command<br>e of comm<br>of buffer<br>f buffer<br>e of buff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | e rege to block the block | g.<br>able<br>ock<br>block<br>block<br>ik |        |
|          |                                    |                                                  |                                              |                                                    | 0307<br>0307<br>0307                                                                 | 894                                                              | 30\$:              | ; Load                                                      | DR750 re                                                                    | gisters                                                                                    |                                                                            |                                                          |                                                                  |                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |        |
|          | 50                                 | 51 <sub>0C</sub>                                 | 01<br>A4                                     | DO                                                 | 0307<br>030A<br>030E                                                                 | 896<br>897                                                       |                    | MOVAL                                                       | WDR 750<br>DR_UCSD                                                          | SBR,R1<br>(R4),R0                                                                          |                                                                            | R                                                        | 1 will                                                           | step                                                                           | through<br>to WCS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | register<br>data reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | r                                         |        |
|          | 08                                 | A4<br>60                                         | 81<br>0C                                     | 9E<br>DB                                           | 030E<br>030E<br>0312                                                                 | 898<br>899<br>900                                                |                    | MOVAB<br>MF PR                                              | (R1)+,0<br>#PR\$_SE                                                         | R_WCSA(R4<br>BR,(R0)                                                                       | 6)                                                                         | : S                                                      | tore a                                                           | ddress                                                                         | of next                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | t registe<br>sys. bas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | er                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                           |        |

XFDRIVER V04-000

|       |                                                                                     | - DR32 DRIVER<br>STARTIO - Entry point                                                                         | L 16 16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 Page 20 t to start I/O 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1 (6)                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60    | 00000000°GF<br>60 44 A2<br>60 34 A2<br>60 2C A2<br>60 48 A2<br>60 40 A2<br>60 38 A2 | DO 0315 901<br>DO 031C 902<br>DO 0320 903<br>DO 0324 904<br>DO 0328 905<br>DO 032C 906<br>DO 0330 907          | MOVL G^MMG\$GL GPTBASE,(R0) : DR_GBR = address of global page table MOVL IRPE\$L_CBLKADR(R2),(R0) : DR_CMDBVA = address of command block MOVL IRPE\$L_BCNT1(R2),(R0) : DR_CMDLEN = length of command block MOVL IRPE\$L_SVAPTE1(R2),(R0) : DR_CMDSVAPTE = \$VAPTE of command block MOVL IRPE\$L_BBLKADR(R2),(R0) : DR_BFRBVA = address of buffer block MOVL IRPE\$L_BCNT2(R2),(R0) : DR_BFRSVAPTE = \$VAPTE of buffer block MOVL IRPE\$L_SVAPTE2(R2),(R0) : DR_BFRSVAPTE = \$VAPTE of buffer block |
|       |                                                                                     | 0334 908<br>0334 909 35\$:<br>0334 910<br>0334 911                                                             | ; Check for WCS valid and start the DR going!                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 04 A4 | 00000800 8F<br>10<br>64 0700 8F                                                     | 0334 911<br>03 0334 912<br>13 0342 913<br>3C 0344 914<br>0349 915<br>05 034C 916<br>034D 917<br>034D 918       | DSBINT #31 BITL #DR_UTL_M_VALID,DR_UTL(R4); Is WCS valid? BEQL 50\$ No. error! MOVZWL #DCR_K_CLRHLT,DR_DCR(R4); Clear Halt function ENBINT RSB                                                                                                                                                                                                                                                                                                                                                     |
|       |                                                                                     | 034D 919                                                                                                       | ; Error - Adapter has no power                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | 50 0364 8F                                                                          | 034D 920 40\$:<br>034D 921<br>3C 034D 922<br>11 0352 923<br>0354 924<br>0354 925 50\$:<br>0354 926<br>0354 927 | MOVZWL #SS\$_POWERFAIL,RO ; Status<br>BRB 70\$                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |                                                                                     | 0354 925 508:                                                                                                  | ; Error - WCS not valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 50 035C 8F                                                                          | 3C 0357 928<br>11 035C 929                                                                                     | ENBINT SSS_MCNOTVALID,RO ; Status BRB 70\$                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |                                                                                     | 035E 930<br>035E 931 60\$:<br>035E 932<br>3C 035E 933<br>0361 934<br>0361 935 70\$:<br>0361 936                | ; Error - Data rate too high                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 50 14                                                                               | 3c 035E 933                                                                                                    | MOVZWL #SS\$_BADPARAM,RO ; Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |                                                                                     | 0361 934<br>0361 935 70\$:<br>0361 936                                                                         | ; Complete I/O with error in RO                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | 51<br>0136                                                                          | 04 0361 937<br>31 0363 938                                                                                     | CLRL R1 ; Clear second half of I/O status block BRW REQ_COMPLETE                                                                                                                                                                                                                                                                                                                                                                                                                                   |

XFDRIVER VO4-000

9E 63

```
- DR32 DRIVER
16-SEP-1984 00:21:10
INTERRUPT_SVC - Interrupt service routin 5-SEP-1984 00:20:00
                                                                                                   VAX/VMS Macro VO4-00
[DRIVER.SRC]XFDRIVER.MAR;1
                                      .SBTTL INTERRUPT_SVC - Interrupt service routine
                   941
943
943
944
945
946
948
949
                           FUNCTIONAL DESCRIPTION:
                                     This is the interrupt service routine for DR32 interrupts. It reads the DCR register, clears the interrupting condition(s), and calls HANDLE_INT to handle the interrupt. Note that this routine executes at device IPL while HANDLE_INT forks and therefore executes at fork IPL.
                            CALLING SEQUENCE:
                                      JSB from interrupt vector in CRB. This routine cleans up
                                      the stack and does an REI.
                            INPUT PARAMETERS:
                                      None
                   959
                   960
961
                            IMPLICIT INPUTS:
                   962
963
                                      The stack on entry is as follows:
                   964
                                                                            Address of IDB address
                                                                           Saved R2
Saved R3
                   965
                                                    4(SP)
                   966
                                                    8(SP)
                                                                            Saved R4
Saved R5
                                                   12(SP)
                                                   16(SP)
                                                   20(SP)
                                                                            Interrupt PC
                                                  24(SP)
                                                                            Interrupt PSL
                            OUTPUT PARAMETERS:
                                      None
                            IMPLICIT OUTPUTS:
                                      None
                   980
981
983
983
984
985
986
987
988
9991
9993
9995
9996
                            COMPLETION CODES:
                                      None
                            SIDE EFFECTS:
                                      None
                                                  IDB$L CSR+4 EQ IDB$L OWNER DR_DCR_V_PWR_DN EQ DR_DCR_V
                                      ASSUME
                                                                             EQ DR DCR V PWR UP+1
                                      ASSUME
                         INTERRUPT SVC:
                                                  a(SP)+,R3
IDB$L_CSR(R3),R4
 D0
70
                                                                                        : Get address of IDB in R3
: CSR -> R4, UCB-> R5
                                      PVOM
                                      : Get contents of DCR and OR into DCR in UCB
```

M 16

BBSS

BSBB

MOVQ

MOVO

#UCB V FKLOCK,-UCB\$Q\_DEVSTS(R5),50\$

; finish cleaning up stack and return from interrupt

HANDLE\_INT

(SP)+,R2

(SP)+,R4

; Branch if interlock is set

Restore R2 and R3; Restore R4 and R5

; Handle interrupt (at fork IPL)

01 A5

07

8E 8E

02 68

52 54

EZ

10

7D 7D 02

03CB 03CD 03CD

1034

1040

508:

23 (8)

```
.SBTTL HANDLE_INT - Handle the interrupt
                       : FUNCTIONAL DESCRIPTION:
                                        This routine actually handles the interrupts. It is called by INTERRUPT SVC at device IPL but immediately forks to fork IPL. There are four interrupting conditions: power up, power down, abort, and packet interrupts. This routine checks for all of these conditions. If there is an I/O in progress, there are three possible exits from this routine: If the DR is halted, then the I/O is completed (with either a success or failure status code). If the DR is not halted, then if no errors were detected the transfer continues. If any errors were detected, the transfer is aborted.
                           CALLING SEQUENCE:
                                         BSBB from interrupt service routine
                           INPUT PARAMETERS:
                                                          Address of first device CSR
                                                          Address of UCB
                           IMPLICIT INPUTS:
                                        Offset UCB$L_DCR in the UCB contains the device DCR register
                           DUTPUT PARAMETERS:
                                        None
                           IMPLICIT OUTPUTS:
                                        None
                           COMPLETION CODES:
                                        None
                           SIDE EFFECTS:
            1084
1085
1086
1087
                                         None
                      HANDLE_INT:
            1089
                                         IOFORK
            1091
1092
1093
                                           Clear FORK interlock, get DCR from UCB, and clear DCR in UCB. This clear must be performed by a BICL as it is possible for the interrupt service routine to OR in additional bits
            1094
1095
1096
1097
1098
1099
                                            between the get DCR and the clear DCR. These additional bits will be handled by the next interrupt.
03DA
03DA
                                                         UCB$B DIPL(R5)
#UCB M FKLOCK.-
UCB$Q DEVSTS(R5)
                                                                                                               : Raise IPL to prevent race condition : Clear fork interlock
                                         SETIPL
                                         BICW
```

|  |  | 4 |
|--|--|---|
|  |  | 4 |
|  |  | ď |
|  |  | 4 |
|  |  | 4 |
|  |  | 4 |

|                      |                        |                                          | - DR                                   | 32 DRI                                       | VER<br>- Handle t                                         | ne interr                                            | D 1<br>16-SEP-1984<br>Upt 5-SEP-1984                                                                                                                                                                                                                                          | 00:21:10 VAX/VMS Macro V04-00 Page 00:20:00 EDRIVER.SRCJXFDRIVER.MAR;1                                                                    | 24 (8) |
|----------------------|------------------------|------------------------------------------|----------------------------------------|----------------------------------------------|-----------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 52<br>00A0<br>0A00   | 00A0<br>C5             | C5<br>52<br>52                           | DO<br>CA<br>DO                         | 03E2<br>03E7<br>03EC<br>03F0                 | 1100<br>1101<br>1102<br>1103                              | MOVL<br>BICL<br>SETIPL<br>MOVL                       | UCB\$L DCR(R5),R2<br>R2,UCB\$L DCR(R5)                                                                                                                                                                                                                                        | ; Get DCR from UCB<br>; Clear DCR in UCB<br>; Lower to fork IPL<br>; Save DCR for reg. dump routine                                       | (0)    |
| 53                   | 50 58                  | A5<br>01<br>51                           | 30<br>30<br>04                         | 03F5<br>03F9<br>03FC                         | 1104<br>1105<br>1106<br>1107<br>1108                      | MOVL<br>MOVZWL<br>CLRL                               | UCB\$L_IRP(R5),R3<br>#SS\$_RORMAL,RO<br>R1                                                                                                                                                                                                                                    | ; Get address of IRP (if there is one); Assume success; Clear second half of I/O status block                                             |        |
|                      |                        |                                          |                                        | 03FE<br>03FE<br>03FE<br>03FE                 | 1109<br>1110<br>1111<br>1112<br>1113                      | Now                                                  | test for cause of inter<br>1) Power up interrup<br>2) Power down interrupt<br>3) Abort interrupt<br>4) Packet interrupt                                                                                                                                                       |                                                                                                                                           |        |
|                      |                        |                                          |                                        | 03FE                                         | 1115                                                      | ; Test                                               | for power up interrupt                                                                                                                                                                                                                                                        |                                                                                                                                           |        |
| 00<br>68<br>05<br>50 | 52<br>A5<br>52<br>0364 | 16<br>01<br>11<br>8F                     | E1<br>88<br>E1<br>30                   | 03FE<br>0402<br>0406<br>040A<br>040F         | 1116<br>1117<br>1118<br>1119<br>1120<br>1121              | BBC<br>BISW<br>BBC<br>MOVZWL                         | #DR_DCR_V_DCRHLT,R2,2                                                                                                                                                                                                                                                         | OS : Branch if not power up interrupt DEVSTS(R5) : Set adapter power up bit US : Branch if device is not halted : Load powerfail status   |        |
|                      |                        |                                          |                                        | 040F                                         | 1122 208:                                                 | ; Test                                               | for power down interru                                                                                                                                                                                                                                                        | pt                                                                                                                                        |        |
| 00<br>68<br>64<br>50 | 52<br>A5<br>A5<br>0364 | 17<br>01<br>20<br>8f                     | E1<br>AA<br>A8<br>3C                   | 040F<br>040F<br>0413<br>0417                 | 1124<br>1125<br>1126<br>1127                              | BBC<br>BICW<br>BISW<br>MOVZWL                        | WUCB M_ADPPWRUP, UCBSW_ST                                                                                                                                                                                                                                                     | O\$ ; Branch if not power down interrupt DEVSTS(R5) ; Clear adapter power up bit S(R5) ; Set powerfail bit in UCB ; Load powerfail status |        |
|                      |                        |                                          |                                        | 0420                                         | 1129 308:                                                 | ; Skip                                               | remaining code if we d                                                                                                                                                                                                                                                        | on't have an IRP (UCB is not busy).                                                                                                       |        |
|                      | 19 64                  | 08<br>A5                                 | El                                     | 0420<br>0422<br>0422                         | 1130<br>1131<br>1132<br>1133                              | BBC                                                  | #UCB\$V_BSY,-<br>UCB\$W_STS(R5),DONE                                                                                                                                                                                                                                          | : Branch if we don't have an IRP                                                                                                          |        |
|                      |                        |                                          |                                        | 0425                                         | 1133<br>1134<br>1135                                      | ; Test                                               | for Abort Interrupt                                                                                                                                                                                                                                                           |                                                                                                                                           |        |
| 03                   |                        | 12<br>086                                | E1 30                                  | 0425<br>0429<br>0420                         | 1136<br>1137<br>1138                                      | BBC<br>BSBW                                          | #DR_DCR_V_DCRABT,R2,4                                                                                                                                                                                                                                                         | S; Branch if not abort interrupt; Handle abort interrupt                                                                                  |        |
|                      |                        |                                          |                                        | 042C                                         | 1138<br>1139 40\$:<br>1140                                | ; Test                                               | for packet interrupt                                                                                                                                                                                                                                                          |                                                                                                                                           |        |
| OF                   | 52<br>05<br>6E         | 13<br>3F<br>0F 6<br>50<br>51<br>50<br>3F | E1<br>BB<br>30<br>E8<br>D4<br>70<br>BA | 0420<br>0430<br>0432<br>0435<br>0438<br>0438 | 1141<br>1142<br>1143<br>1144<br>1145<br>1146<br>1147 508: | BBC<br>PUSHR<br>BSBW<br>BLBS<br>CLRL<br>HOVQ<br>POPR | #DR DCR V PKTINT,R2,6<br>#^M <r0,r1,r2,r3,r4,r5<br>QUEUE PKT_AST<br/>R0,50\$<br/>R1<br/>R0,(SP)<br/>#^M<r0,r1,r2,r3,r4,r5< td=""><td>; Queue packet AST<br/>; Success<br/>; Failure to queue AST<br/>; Store status</td><td></td></r0,r1,r2,r3,r4,r5<></r0,r1,r2,r3,r4,r5<br> | ; Queue packet AST<br>; Success<br>; Failure to queue AST<br>; Store status                                                               |        |
|                      |                        | 31                                       |                                        | 043F<br>043F<br>043F<br>043F<br>043F         | 1148<br>1149 60\$:<br>1150                                | : Come<br>send<br>if s                               | here with 1/0 status h                                                                                                                                                                                                                                                        | lock in RO and R1. If DR is halted,<br>e. If the DR is not halted, return<br>ort the DR if the status is failure                          |        |
| 59                   | 52                     | 11<br>02                                 | E0                                     | 043F<br>0443<br>0443                         | 1152<br>1153<br>1154<br>1155<br>1156                      | BBS                                                  | #DR_DCR_V_DCRHLT,R2,-<br>REQ_COMPLETE<br>#UCB_V_ABORT,-                                                                                                                                                                                                                       | Branch if device is halted<br>to request complete<br>Branch if an abort is pending                                                        |        |

XFDRIVER VO4-000

contain I/O status block.

1200

XFDRIVER.

V04-000

```
F 1
- DR32 DRIVER
ABORT INT - Handle abort interrupts
                         .SBTTL ABORT_INT - Handle abort interrupts
                FUNCTIONAL DESCRIPTION:
                         This routine handles abort interrupts. It distinguishes among
                                      These are:
                         four cases.
                                     Driver abort
User and far end device errors
```

4) Other DR32 errors (such as bus errors)
This routine's main purpose is to identify the cause of the abort and to return appropriate status in RO and R1 for use as the I/O status block.
This routine also error logs parity errors and DR32 errors (cases) 3 and 4 above).

BSBB ABORT\_INT

#### INPUT PARAMETERS:

CALLING SEQUENCE:

R2 R4 R5 Contents of DCR Address of first device CSR

Parity errors

Address of UCB

#### IMPLICIT INPUTS:

Offset UCB\$L\_SAVSTATUS in the UCB contains the status for driver aborts

#### **OUTPUT PARAMETERS:**

First longword of I/O status block Second longword of 1/0 status block

#### IMPLICIT OUTPUTS:

None

#### COMPLETION CODES:

contains status left in UCB\$L\_SAVSTATUS for driver aborts, SS\$\_DEVREQERR for user and far end device errors, SS\$\_PARITY for parity errors, and SS\$\_CTRLERR for other errors. RO

O for driver aborts, and a combination of bits from the DCR, UTILITY, and DSL R1 registers for all other errors.

#### SIDE EFFECTS:

None

ABORT\_INT:

|                                                       | - DR32 DRIVER<br>ABORT_INT - Handle abort                                                                              | 6 1<br>16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 Page 27<br>t interrupts 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1 (9)                                                                                                                                                  |
|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                       | 0482 1259                                                                                                              | ; Test for Driver abort.                                                                                                                                                                                                                                                     |
| 50 00A4 C5                                            | E1 0482 1261<br>D0 0486 1262<br>D4 048B 1263<br>05 04BD 1264                                                           | BBC #DR DCR V EXTABT.R2,10\$ : Branch if not driver abort UCB\$L_SXVSTATUS(R5),R0 : Get status saved when driver set abort CLRL R1 : Second longword of IOSB is 0 : Return                                                                                                   |
|                                                       | 05 04BD 1264<br>04BE 1265<br>04BE 1266 10\$:<br>04BE 1267                                                              | ; Collect bits for second longword of 1/0 status block as all ; other errors require this.                                                                                                                                                                                   |
|                                                       | 04BE 1269<br>04BE 1270<br>04BE 1271                                                                                    | ASSUME DR_UTL_V_WCSPE EQ DR_DCR_V_WCSPE ASSUME DR_750_DSL EQ 0                                                                                                                                                                                                               |
| 07 68 A5 03<br>51 0400 C4                             | E0 04BE 1272<br>D0 04C3 1273                                                                                           | BBS #UCB V DR750,UCB\$W_DEVSTS(R5),20\$; Branch if DR750 MOVL DR 780_DSL(R4),R1; Start out with all of the DSL BRB 30\$                                                                                                                                                      |
| 51 00 A4<br>52 5500 8F                                | D4 04CA 1275 208:<br>D0 04CD 1276<br>B3 04D1 1277 308:<br>04D6 1278                                                    | CLRL DR_WCSA(R4)  MOVL DR_WCSD(R4),R1  BITW #DR_DCR_M_ID1ERR!-  DR_DCR_M_ID1TO!-  DR_DCR_M_ID2ERR!-  These are sort of bus errors                                                                                                                                            |
| 00 51 1B<br>04 52 0F<br>00 51 1C<br>50 04 A4          | 13 0406 1281<br>E2 0408 1282<br>E1 040C 1283 408:<br>E2 04E0 1284                                                      | DR_DCR_M_ID2TO.R2  BEQL 40\$  BBSS                                                                                                                                                                                                                                           |
| 03 68 A5 03<br>50 52<br>50 50 E4 8F<br>10 50<br>51 03 | 04E8 1286<br>E1 04E8 1287<br>D0 04ED 1288<br>78 04F0 1289 50\$:<br>F0 04F5 1290<br>04F8 1291<br>04FA 1292<br>04FA 1293 | BBC #UCB_v_DR750,UCB\$W_DEVSTS(R5),50\$; Branch if DR780  MOVL R2,R0; Get DCR (for parity err bits on DR750)  ASHL #-DR_UTL_v_WCSPE,R0,R0; Shift 3 parity error bits to bit 0  INSV R0,#Xf\$v_IOS_WCSPE,-; and insert in R1  #3,R1                                           |
|                                                       | 04FA 1293<br>04FA 1294                                                                                                 | ; Test for controller error (SS\$_CTRLERR)                                                                                                                                                                                                                                   |
| 51 18000004 8F                                        | 04FA 1294<br>03 04FA 1295<br>0501 1296<br>0501 1297                                                                    | BITL #XF\$M_IOS_BUSERR!- : Test for bus error,                                                                                                                                                                                                                               |
| 10                                                    | 12 0501 1298<br>0503 1299                                                                                              | BNEQ 60\$ ; and invalid PTE ; Have a controller error                                                                                                                                                                                                                        |
|                                                       | 0503 1300                                                                                                              | ; Test for Parity error (SS\$_PARITY)                                                                                                                                                                                                                                        |
| 50 01F4 8F<br>51 E0000000 8F                          | 3C 0503 1302<br>03 0508 1303<br>050F 1304                                                                              | MOVZWL #SS\$ PARITY.RO : Assume yes BITL #XF\$M IOS WCSPE!- : Test for WCS parity error. XF\$M IOS CIPE!- : control interconnect parity error.                                                                                                                               |
| 13                                                    | 050F 1305<br>12 050F 1306                                                                                              | BNEQ 705 ; and data interconnect parity error ; have a parity error                                                                                                                                                                                                          |
|                                                       | 0511 1307<br>0511 1308                                                                                                 | ; Test for user or far end device error (SS\$_DEVREQERR)                                                                                                                                                                                                                     |
| 50 0334 8F<br>51 00801BD0 8F                          | 3C 0511 1309<br>03 0516 1311<br>0510 1312<br>0510 1313<br>0510 1314<br>0510 1315                                       | MOVZWL #SS\$ DEVREGERR.RO  BITL #XF\$M IOS DDIDIS!-  XF\$M IOS RNGERR!-  XF\$M IOS UNGERR!-  XF\$M IOS INVPKT!-  XF\$M IOS FREGMT!-  XF\$M IOS FREGMT!-  Test for DDI disable,  range error,  unaligned queue error,  invalid packet,  xF\$M IOS FREGMT!-  Tree queue empty, |

XFDRIVER VO4-000 - DR32 DRIVER QUEUE\_PKT\_AST - Queue packet AST

16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1

Page 29 (10)

.SBTTL QUEUE\_PKT\_AST - Queue packet AST

# : FUNCTIONAL DESCRIPTION:

This routine is called to queue an AST to the user process and set an event flag to indicate that a packet was placed on the process's termination queue. Both queueing the AST and setting the event flag are optional; either or both may occur. An AST is queued if a packet AST address is specified in the I/O packet and the event flag is set if the modifier IOS\_SETEVF is present in the I/O subfunction code. Note that this routine forks to Queue AST IPL before queueing the AST or setting the event flag.

## CALLING SEQUENCE:

BSBW QUEUE\_PKT\_AST

INPUT PARAMETERS:

R3 Address of I/O packet
R5 Address of UCB

#### IMPLICIT INPUTS:

Various fields in the I/O packet

#### **OUTPUT PARAMETERS:**

RO Completion code

#### IMPLICIT OUTPUTS:

None

#### COMPLETION CODES:

SS\$\_NORMAL Normal successful completion Insufficient dynamic memory (to allocate an ACB) SS\$\_EXQUOTA Exceeded AST quota

#### SIDE EFFECTS:

R1,R2,R3,R4 and R5 are not preserved. REPEAT R5!!!

# QUEUE\_PKT\_AST:

: Make sure the process has enough AST quota to allocate a FORK/AST block.

MOVZWL IRP\$L PID(R3),R5
PUSHL G^SCH\$GL PCBVEC
MOVL a(SP)+[R5],R5
MOVZWL #SS\$ EXQUOTA,R0
TSTW PCB\$Q ASTCNT(R5)
BLEQ 10\$

Get process index Push address of PCB table Get PCB address Assume error Enough AST quota left? No!

55 OC A3 3C 000000000 GF DD 55 9E45 DO 50 1C 3C 38 A5 B5

| XFDRIVER<br>VO4-000 |       |                 |                            |                                        | - DR                                     | R32 DRIVER<br>UE_PKT_AST - Que                                                                                        | o packet A                                                      | J 1<br>16-SEP-1<br>ST S-SEP-1                                                                                    | 984 00:21<br>1984 00:20     | :10 VAX/VMS Macro VO4-00 Page 3<br>:00 [DRIVER.SRC]XFDRIVER.MAR;1 (1                                                                                                                                          |
|---------------------|-------|-----------------|----------------------------|----------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |       |                 | 38                         | A5                                     | 87                                       |                                                                                                                       | DECW                                                            | PCBSW_ASTCHT(R5)                                                                                                 |                             | Yes, take one away                                                                                                                                                                                            |
|                     |       |                 |                            |                                        |                                          | 0544 1396<br>0544 1397                                                                                                | ; Allo                                                          |                                                                                                                  |                             | a fork block and AST control block                                                                                                                                                                            |
|                     |       | 51<br>000<br>50 | 0004<br>000000<br>0124     | 53<br>1 GF<br>53                       | 3C<br>DD<br>16<br>8ED0<br>E8<br>3C<br>86 | 0544 1398<br>0544 1399<br>0549 1400<br>0548 1401<br>0551 1402<br>0554 1403<br>0557 1404<br>0550 1405<br>0556 1406 108 | MOVZWL<br>PUSHL<br>JSB<br>POPL<br>BLBS<br>MOVZWL<br>INCW<br>RSB | #IRPSK_LENGTH,R1 R3 G^EXESALONONPAGED R3 R0,208 #S\$\$ INSFMEM,R0 PCB\$D_ASTCNT(R5)                              |                             | Length = an I/O pkt because it's fast<br>Save R3<br>Returns pointer to packet in R2<br>Restore R3<br>Successful allocation<br>Error - insufficient dynamic memory!<br>Add 1 back to AST quota<br>Error return |
|                     |       |                 |                            |                                        |                                          | 0560 1407<br>0560 1408 20\$<br>0560 1409                                                                              |                                                                 | size and type into<br>h returns success s                                                                        |                             | d then fork to Queue AST IPL                                                                                                                                                                                  |
|                     |       |                 |                            |                                        |                                          | 0560 1410<br>0560 1411<br>0560 1412<br>0560 1413                                                                      | ASSUME<br>ASSUME                                                | IRPSB_TYPE EQ IRPS<br>FKB\$B_FIPL EQ IRPS                                                                        | SW_SIZE+2<br>BB_RMOD        |                                                                                                                                                                                                               |
|                     | 08 A2 | 000             | 200C4<br>3 A2<br>55<br>50  | 8F<br>06<br>52<br>01                   | 90<br>90<br>90<br>30                     | 0560 1414<br>0568 1415<br>056C 1416<br>056F 1417<br>057Z 1418                                                         | MOVL<br>MOVB<br>MOVL<br>MOVZWŁ<br>FORK                          | # <dyn\$c acb@16="">+1<br/>#IPL\$_QUEUEAST,FR<br/>R2.R5<br/>#SS\$_NORMAL,R0</dyn\$c>                             | IRP\$K_LENG<br>(B\$B_FIPL() | TH.IRP\$W_SIZE(R2) ; Size and type R2) ; Set fork IPL = Queue AST IPL ; R5 must point to fork block ; Return normal status to caller ; Fork!                                                                  |
|                     |       |                 |                            |                                        |                                          | 0578 1419<br>0578 1420<br>0578 1421                                                                                   | ; Build<br>; R3 po                                              | d AST control block<br>pints to I/O packet                                                                       | in prepar<br>R. RS point    | ration for queueing AST.<br>ts to AST control block.                                                                                                                                                          |
|                     |       |                 |                            |                                        |                                          | 0578 1423<br>0578 1424                                                                                                | ASSUME<br>ASSUME                                                | IRPSL_PKTASTPRM E                                                                                                | Q IRPSL PI                  | KTASTADR+4                                                                                                                                                                                                    |
|                     |       | 51<br>00        | A5<br>40<br>10<br>0E<br>0E | A3<br>51<br>A3<br>A5<br>A5<br>A5<br>BF | 90<br>88                                 |                                                                                                                       | MOVL<br>MOVQ<br>MOVB<br>BISB                                    | IRPSL PID(R3),R1<br>R1,ACBSL PID(R5)<br>IRPSL PKTASTADR(R<br>ACBSL AST(R5)<br>IRPSB RMOD(R3),-<br>ACBSB RMOD(R5) | (3),-                       | Get PID and save for SCH\$POSTEF Store PID in ACB Store packet AST address and parameter in ACB Store access mode  ) ; Set AST quota accounting flag                                                          |
|                     |       | VO N.           | 40                         |                                        | 00                                       | 058F 1433<br>058F 1434 30\$<br>058F 1435                                                                              |                                                                 |                                                                                                                  |                             | on code specifies it                                                                                                                                                                                          |
|                     |       | OA 20           | 52<br>A3<br>300000         | 01<br>06<br>A3                         | 9A<br>E1<br>9A<br>16                     | 058F 1436<br>0592 1437<br>0597 1438<br>059B 1439                                                                      | MOVZBL<br>BBC<br>MOVZBL<br>JSB                                  | #PRIS IOCOM.R2                                                                                                   |                             | Priority incr. class = 1/0 complete<br>0,40\$; Br. if don't post event flag<br>Get event flag number<br>Post event flag                                                                                       |
|                     |       |                 |                            |                                        |                                          | 05A1 1441 40\$                                                                                                        | ; Now                                                           |                                                                                                                  |                             | te AST control block.                                                                                                                                                                                         |
|                     |       | 000             | 10<br>000000               | 06<br>06<br>0 GF                       | D5<br>13<br>17                           | 05A1 1442<br>05A1 1443<br>05A4 1444<br>05A6 1445<br>05AC 1446                                                         | TSTL<br>BEQL<br>JMP                                             | ACB\$L_AST(R5) 50\$ G^SCH\$QAST                                                                                  | ; 1                         | Is AST specified? (Address non-zero)? No, deallocate ACB Yes, queue AST. SCH\$QAST returns to                                                                                                                 |
|                     |       |                 |                            |                                        |                                          | 05AC 1446<br>05AC 1447<br>05AC 1448 50\$                                                                              | ; Don'                                                          | give AST, so deal                                                                                                | locate pad                  | cket.                                                                                                                                                                                                         |
|                     |       | 000             | 000000                     | A5<br>GF                               | 3C                                       | 05AC 1449<br>05AC 1450<br>05B0 1451                                                                                   | MOVZWL                                                          | ACB\$L_PID(R5),R2<br>G^SCH\$GL_PCBVEC                                                                            | : 6                         | But first increment AST quota<br>Push address of PCB table                                                                                                                                                    |

(10)

UCB V\_ADPPWRUP EQ 0 IDB\$L\_CSR EQ 0

UCBSW\_DEVSTS(R5),60\$

; Branch if adapter has no power

: Save R4

ASSUME ASSUME

BLBC

PUSHL

13 68 A5

```
.SBTTL REGDUMP - Register Dump Routine
```

# FUNCTIONAL DESCRIPTION:

This routine copies relevant DR32 registers into either a diagnostic buffer or an error log buffer. It is called from the error logging routine and from the diagnostic buffer fill routine.

#### CALLING SEQUENCE:

JSB REGDUMP

N 1

#### INPUT PARAMETERS:

Address of buffer to store registers Address of first device CSR Address of UCB RO R4 R5

IMPLICIT INPUTS:

None

**OUTPUT PARAMETERS:** 

None

IMPLICIT OUTPUTS:

None

COMPLETION CODES:

None

SIDE EFFECTS:

None

|    | 05 68      | 03<br>A5 | EO             | 05F0<br>05F0<br>05F2 | 1563<br>1564<br>1565<br>1566 | REGDUMP | BBS                     | #UCB V DR750<br>UCB\$@_DEVSTS(R5),10\$  | ; If set, yes DR750                                               |
|----|------------|----------|----------------|----------------------|------------------------------|---------|-------------------------|-----------------------------------------|-------------------------------------------------------------------|
|    | 52         | 0F<br>03 | DO<br>11       | 05F 8                | 1567<br>1568<br>1569         |         | MOVL<br>BRB             | #15,R2<br>20\$                          | : Number of reg. in first DR780 group<br>: Go start               |
|    | 52         | 07       | DO             | 05FA                 | 1570                         | 10\$:   | MOVL                    | #7,R2                                   | ; Number of reg. in first DR750 group                             |
| 80 | 80<br>00A8 | 28<br>C5 | D0             | 05FD<br>0600         | 1572                         | 20\$:   | MOVL.                   | #40,(R0)+<br>UCB\$L_SAVDCR(R5),(R0)+    | : Store number of registers to be saved : Store copy of saved DCR |
| 51 | 80<br>FA   | 81<br>52 | DE<br>DO<br>F5 | 0605<br>0609<br>060C | 1577                         | 30\$:   | MOVAL<br>MOVL<br>SOBGTR | DR_UTL(R4),R1<br>(RT)+,(R0)+<br>R2,30\$ | Address of first register group<br>Store next register<br>Repeat  |
|    |            | 03       | EO             | 060F                 | 1578<br>1579                 |         | BBS                     | #UCB_V_DR750,-                          |                                                                   |

|   |    |                                 |                            | - DR<br>REGD               | 32 DR                                                | IVER<br>Register                                                 | Dump Routine                           | 8 2<br>16-SEP-1984<br>5-SEP-1984                                         | 00:21:10 YAX/VMS Macro V04-00 Page 35<br>00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1 (12)                                                                            |
|---|----|---------------------------------|----------------------------|----------------------------|------------------------------------------------------|------------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | 51 | 10 68<br>52<br>0400<br>80<br>FA | 18<br>C4<br>81             | DO DE DO F5                | 0611<br>0614<br>0614<br>0617<br>0610<br>061F<br>0622 | 1580<br>1581<br>1582<br>1583<br>1584<br>401<br>1585<br>1586      | MOVL<br>MOVAL<br>MOVL<br>SOBGTR<br>BRB | UCB\$W_DEVSTS(R5),50\$ #24,R2 DR 780 DSL(R4),R1 (RT)+,TRO)+ R2,40\$ 70\$ | ; If set, then DR750<br>; Number of registers in second group<br>; Address of second register group<br>; Store next register<br>; Repeat                     |
|   | 51 | 52<br>08<br>0C<br>80<br>FA      | 20<br>A4<br>A4<br>61<br>52 | 00<br>04<br>06<br>00<br>F5 | 0624<br>0627<br>0628<br>0631<br>0634                 | 1588 508<br>1589<br>1590<br>1591 608<br>1592<br>1593<br>1594 708 | CLRL<br>MOVAL<br>MOVL<br>SOBGTR        | #32,R2<br>DR_WCSA(R4)<br>DR_WCSD(R4),R1<br>(RT),(R0)+<br>R2,60\$         | Number of registers in second group<br>Set indirect register address to zero<br>Address of data register<br>Stores next register and bumps adderss<br>Repeat |

XFDRIVER VO4-000

```
C 2
                                                    - DR32 DRIVER UNIT_INIT - Unit initialization
XFDRIVER
VO4-000
                                                                                                                                                          VAX/VMS Macro VO4-00
[DRIVER.SRC]XFDRIVER.MAR;1
                                                                                            .SBTTL UNIT_INIT - Unit initialization
                                                                                 FUNCTIONAL DESCRIPTION:
                                                                                          This routine is entered when the driver is loaded and on system power recovery. On driver load, it initializes the UCB and sets the protection on the page containing the GO bit to user writeable. It also determines which cpu type it is running on (11/780 or 11/750) and sets a bit in UCBSW_DEVSTS to indicate which one. On power recovery, it simply returns. Power recovery is actually handled in the interrupt handler.
                                                                                  CALLING SEQUENCE:
                                                                                           JSB
                                                                                                        UNIT_INIT
                                                                                  INPUT PARAMETERS:
                                                                                           R5
                                                                                                        Address of UCB
                                                                                  IMPLICIT INPUTS:
                                                                                           None
                                                                                  OUTPUT PARAMETERS:
                                                                                           None
                                                                                  IMPLICIT OUTPUTS:
                                                                                           None
                                                                                  COMPLETION CODES:
                                                                                           None
                                                                                  SIDE EFFECTS:
                                                                                           RO, R1, R2, AND R4 ARE NOT PRESERVED
                                                                              UNIT_INIT:
                                                                                           : Determine if this is initial loading or a power recovery.
                                                                                                        #UCB$V_POWER,UCB$W_STS(R5),INIT_DONE ; Branch if power recovery
                            5D 64 A5
                                              05
                                                     EO
                                                                                            : Get address of IDB and first device CSR
                                    54 P
                                                                                                        UCB$L_CRB(R5),R1 ; Get address of CRB
CRB$L_INTD+VEC$L_IDB(R1),R2 ; Get address of IDB
IDB$L_CSR(R2),R4 ; Get address of first device CSR
                                                      D0
D0
                                                                                            MOVL
                                                                                            MOVL
                                                                                            MOVL
                                                                                            : Make UCB owner of IDB and reset DR.
                                 04 A2
                                                      DO
                                              55
                                                                                            MOVL
                                                                                                         R5, IDB$L_OWNER(R2)
                                                                                                                                               : Make UCB owner of IDB
```

|          |                        |                                 |                         |          | 32 DRIVER                                                                        | it initia      | lization                                | D 2<br>16-SEP-1984 00:21:10 VAX/VMS 1<br>5-SEP-1984 00:20:00 [DRIVER.                                                                                                                                          | Macro V04-00 Page 37<br>SRC]XFDRIVER.MAR;1 (13)                                     |
|----------|------------------------|---------------------------------|-------------------------|----------|----------------------------------------------------------------------------------|----------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
|          | 64                     | 4000<br>0600                    | 8F                      | 3C<br>3C | 0649 165<br>064E 165                                                             | 3              | MOVZWL                                  | #DCR_K_RESET.DR_DCR(R4) : Reset DR.<br>#DCR_K_SETINTENB,DR_DCR(R4) ; Enable                                                                                                                                    | e interrupts                                                                        |
|          |                        |                                 |                         |          | 0653 165<br>0653 165                                                             |                | ; Set p                                 | otection on page containing GO bit to u                                                                                                                                                                        | ser mode writeable.                                                                 |
| 51<br>52 | 50<br>50<br>0000<br>52 | 0200<br>15<br>00000<br>18<br>62 | 09<br>1 GF<br>241<br>04 | DEFO     | 0653 165<br>0658 165<br>0650 166<br>0664 166<br>0668 166<br>0668 166             | 8              | MOVAL<br>EXTZV<br>MOVL<br>MOVAL<br>INSV | <pre>#PRISC_UW,#PIESV_PROT,- ; Set protection #PTESS_PROT,(R2)</pre>                                                                                                                                           |                                                                                     |
|          |                        |                                 |                         |          | 0670 166<br>0670 166                                                             | 5              |                                         | adapter has power so set adapter power                                                                                                                                                                         |                                                                                     |
|          | 68                     | A5                              | 01                      | A8       | 0670 166<br>0670 166                                                             | 7              | BISW                                    | #UCB_M_ADPPWRUP,UCB\$W_DEVSTS(R5)                                                                                                                                                                              | up ove                                                                              |
|          |                        |                                 |                         |          | 0674 166<br>0674 167<br>0674 167<br>0674 167<br>0674 167<br>0674 167<br>0674 167 | 90123456       | Now de suppo any o bit in to inc        | termine which type of DR32 we have by s<br>ype of cpu we have. Currently, the onl<br>ted are the DR780 and the DR750. If we<br>her cpu type, about all we can do is no<br>the UCB. Also note that we set a bit | y DR32s<br>(somehow) get<br>t set the online<br>in the UCB<br>he rest of the driver |
|          |                        |                                 |                         |          | 0674 167<br>0674 167                                                             | 8              | ASSUME                                  | DT\$_DR750 EQ DT\$_DR780+1                                                                                                                                                                                     |                                                                                     |
|          | 41                     | A5                              | 02                      | 90       | 0674 167<br>0674 168<br>0678 168                                                 | 0              | MOVB                                    | #NTS_DR780,UCB\$B_DEVTYPE(R5) ; Assum                                                                                                                                                                          | e device type is DR780                                                              |
|          |                        |                                 |                         |          | 0678 168                                                                         | 2              | CPUDISP                                 | <pre><dr_780,dr_750,dr_730,dr_790> ; * Dis</dr_780,dr_750,dr_730,dr_790></pre>                                                                                                                                 | patch on CPU type *                                                                 |
|          | 68                     | A5 41                           | A5<br>08                | 96<br>A8 | 068C 168<br>068C 168<br>068F 168<br>0693 168<br>0693 168                         | 4 DR_750:<br>5 | BISM                                    | UCB\$B_DEVTYPE(R5) #UCB_M_DR750,UCB\$W_DEVSTS(R5)                                                                                                                                                              | device type be DR750<br>R750 bit in UCB<br>through to                               |
|          | 64                     | A5                              | 10                      | AB       | 0693 168                                                                         | 8 DR 790:      | BISW                                    | #UCB\$M_ONLINE,UCB\$W_STS(R5) : Same : Set o                                                                                                                                                                   | action as for DR780.<br>nline bit                                                   |
|          |                        |                                 |                         |          | 0693 168<br>0697 169<br>0697 169<br>0697 169<br>0697 169<br>0697 169             | 4              |                                         | ; * End                                                                                                                                                                                                        | of cpu dependent code *                                                             |
|          |                        |                                 |                         | 05       | 0697 169<br>0697 169<br>0698 169<br>0698 169<br>0698 170<br>0698 170<br>0698 170 | S INIT_DO      | NE:<br>RSB                              | ; End of driver                                                                                                                                                                                                |                                                                                     |

XFDRIVER

| XFDRIVER<br>Symbol table                                                                                                                               | - DR32 DRIVER                                                                                                                                                              |                            | 16-SEP-1984 00:21:10 VAX/VMS Macro V04-00<br>5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1                                                                                                                                                                                                                                                                                                                         | Page 38 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| SSS SOP ABORT ABORT INT ABORT 10 ACBSB RMOD ACBSL AST ACBSL ASTPRM ACBSL PID                                                                           | = 00000002                                                                                                                                                                 | 02<br>03<br>03             | DR 780 DSL DR 780 GBR DR 780 SBR DR 780 SBR DR 790 DR DCR DR DCR M DCRABT DR DCR M DCRHLT DR DCR M DCRHLT DR DCR M ID1ERR DR DCR M ID1ERR DR DCR M ID2ERR DR DCR M ID2ERR DR DCR M ID2TO DR DCR M PARERR DR DCR M PARERR DR DCR M PARERR DR DCR M PWR DN DR DCR M PWR UP DR DCR W PWR UP DR DCR W PWR UP DR DCR V DCRABT D 00000012 |         |
| CCESS_VIO<br>LL_OK<br>TS_DR                                                                                                                            | = 0000000C<br>= 00000040<br>00000193 R 0<br>000001A5 R 0                                                                                                                   | 33                         | DR DCR M ID1ERR = 00001000 DR DCR M ID1TO = 00004000 DR DCR M ID2ERR = 00000100 DR DCR M ID2TO = 00000400 DR DCR M PARERR = 80000000                                                                                                                                                                                                                                                                                |         |
| OUGS UNSUPRICPU ANCEL IO ANCEL IO CS REALTIME OCR K CLRABTINT OCR K CLRPKTINT OCR K CLRPWRON OCR K CLRPWRUP OCR K RESET OCR K SETEXTABT                | 000005C6 R<br>= 00000060<br>= 00000400<br>= 00003000<br>= 00003000<br>= 00004000<br>= 00004000<br>= 00002000<br>= 00002000<br>= 00000600                                   | 3                          | DR DCR V DCRHLT = 00000011  DR DCR V EXTABT = 00000018  DR DCR V PKTINT = 00000013  DR DCR V PWR DN = 00000017  DR DCR V PWR UP = 00000016  DR DCR V RDS = 00000006  DR DCR V WCSPE = 0000001C                                                                                                                                                                                                                      |         |
| DBSL_DDT<br>EVSM_AVL<br>EVSM_ELG<br>EVSM_IDV<br>EVSM_ODV<br>EVSM_RTM<br>DNE                                                                            | = 0000000C<br>******* X 0<br>****** X 0<br>****** X 0<br>****** X 0<br>****** X 0                                                                                          | )2<br>)2<br>)2<br>)2<br>)2 | DR_END 00000697 R 03 DR_SBIADR 00000014 DR_SBIBCNT 00000018 DR_USER 00000200                                                                                                                                                                                                                                                                                                                                        |         |
| PTSC_LENGTH<br>PTSC_VERSION<br>PTSINITAB<br>PTSREINITAB<br>PTSTAB<br>R750_MAXRATE                                                                      | = 000000FC                                                                                                                                                                 | )2<br>)2<br>)2             | DR UTL M ENPEAB = 08000000  DR UTL M PARERR = 80000000  DR UTL M VALID = 00000800  DR UTL V PARERR = 0000001F  DR UTL V WCSPE = 0000001C  DR WCSA M SEL = 00000001  DR WCSA M WCS = 80000000                                                                                                                                                                                                                        |         |
| R780 MAXRATE<br>R 730<br>R 750<br>R 750 BFRBVA<br>R 750 BFRLEN<br>R 750 BFRSVAPT<br>R 750 CMDBVA<br>R 750 CMDLEN<br>R 750 CMDSVAPT<br>R 750 DSL        | = 000000FB<br>0000068C R<br>00000007<br>00000008<br>00000003<br>00000005<br>000000005<br>000000000<br>00000001<br>0000041C<br>0000041C<br>0000041C<br>0000041C<br>0000041C | 3 3                        | DR WCSA V SEL = 00000000  DR WCSD                                                                                                                                                                                                                                                                                                                                                                                   |         |
| R 750 DSL<br>R 750 GBR<br>R 750 SBR<br>R 780<br>BF 780 BFRBVA<br>DR 780 BFRLEN<br>DR 780 BFRSVAPT<br>DR 780 CMDBVA<br>DR 780 CMDLEN<br>DR 780 CMDSVAPT | 00000000000000000000000000000000000000                                                                                                                                     | )3                         | DYNSC UCB = 00000010  EMBSL DV REGSAV = 0000004E  ERLSDEVICERR                                                                                                                                                                                                                                                                                                                                                      |         |

| KFDRIVER<br>Symbol table                                                                                                          | - DR32 DRIVER                          |                            | F 2<br>16-SEP-19<br>5-SEP-19                                       | 984 00:21:10 VAX/V<br>984 00:20:00 [DRIV                                                                                                        | MS MER.S | Macro VO4-00<br>GRCJXFDRIVER.MAR; 1 | Page | 39 |
|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------|------|----|
| XESFORK<br>XESGB_CPUTYPE                                                                                                          | ***** X                                | 03                         | LOCK BFR<br>MASKH                                                  | = 01000000                                                                                                                                      |          | 03                                  |      |    |
| XESIOFORK<br>XESMODIFYLOCKR                                                                                                       | ***** X                                | 03<br>03<br>03<br>03<br>03 | MASKL<br>MMG\$GL_GPTBASE<br>MMG\$GL_SPTBASE                        | = 00000040                                                                                                                                      | ×        | 03                                  |      |    |
| XE\$QIODRVPKT<br>XE\$WRITELOCK                                                                                                    | ***** X                                | 03                         | MMGSUNLOCK                                                         | *****                                                                                                                                           | X        | 03<br>03<br>03                      |      |    |
| INISH IO<br>KBSB_FIPL                                                                                                             | = 0000000B<br>00000038 R               | -                          | P1<br>P2<br>P3                                                     | = 00000000<br>= 00000004<br>= 00000008<br>= 00000038<br>= 00000012<br>= 00000001<br>= 00000001                                                  |          |                                     |      |    |
| UNCTABLE<br>UNCTABLIEM                                                                                                            | <b>= 00000028</b>                      | 03                         | P3<br>PCB\$L PID                                                   | = 00000008<br>= 0000060                                                                                                                         |          |                                     |      |    |
| ANDLE INT<br>DB\$L CSR<br>DB\$L OWNER<br>NIT DONE                                                                                 | D00003D4 R                             | 03                         | PCB\$L_PID<br>PCB\$W_ASTCHT<br>PR\$_IPL                            | = 00000038<br>= 0000012                                                                                                                         |          |                                     |      |    |
| BSL OWNER                                                                                                                         | = 00000000<br>= 00000004<br>00000697 R | 03                         | PRS IPL PRS SBR PRS SID TYPZAO                                     | = 00000000                                                                                                                                      |          |                                     |      |    |
| NTERRUPT SVC<br>DSV_SETEVF                                                                                                        | 00000366 R<br>= 0000006                | 03<br>03                   | PRS SID TYP780 PRS TBIS PRIS 10COM                                 | = 0000003A<br>= 00000001                                                                                                                        |          |                                     |      |    |
| DS COADMCODE<br>DS STARTDATA                                                                                                      | = 00000001<br>= 0000038                |                            | PRIST UW<br>PIESS PROT                                             | = 00000004<br>= 00000004                                                                                                                        |          |                                     |      |    |
| DS_STARTDATAP                                                                                                                     | = 00000006                             |                            | PTESV_PROT                                                         | = 00000018                                                                                                                                      |          | A.F.                                |      |    |
| DS VIRTUAL<br>DC\$DIAGBUFILL                                                                                                      | = 0000003F                             | 03                         | QUEUE PKT_AST<br>REGDUMP                                           | 000005F0                                                                                                                                        | R        | 03<br>03<br>03<br>03<br>03          |      |    |
| DCSGW_XFMXRATE<br>DCSMNTVER                                                                                                       | ***** X                                | 03<br>03<br>03<br>03<br>03 | REQ_COMPLETE<br>SCHSGL_PCBVEC                                      | 00000496                                                                                                                                        | RX       | 03                                  |      |    |
| DC\$REQCOM<br>DC\$RETURN                                                                                                          | ***** X                                | 05<br>03                   | SCHSPOSTEF<br>SCHSQAST                                             | *****                                                                                                                                           | X        | 03                                  |      |    |
| DC\$WFIKPCH<br>PL\$_QUEUEAST                                                                                                      | = 00000006                             | 0.3                        | SIZ<br>SS\$_ABORT                                                  | = 00000001<br>= 0000020                                                                                                                         |          |                                     |      |    |
| RPSB_EFN<br>RPSB_FLAGS                                                                                                            | = 00000022<br>= 00000030               |                            | SS\$TACCVIO<br>SS\$TBADPARAM                                       | = 0000000C<br>= 0000014                                                                                                                         |          |                                     |      |    |
| RPSB_RATE<br>RPSB_RMOD                                                                                                            | = 0000003C                             |                            | SS\$_BUFNOTALIGN<br>SS\$_CTRLERR                                   | = 00000324<br>= 0000054                                                                                                                         |          |                                     |      |    |
| DOCD TVDE                                                                                                                         | = 0000000B<br>= 0000000A<br>= 000000C4 |                            | SS\$_DEVACTIVE                                                     | = 00000204                                                                                                                                      |          |                                     |      |    |
| RPSL_ABONT<br>RPSL_EXTEND                                                                                                         | = 00000040<br>= 0000054                |                            | SSS EXQUOTA SSS INSFMEM SSS IVBUFLEN SSS MCNOTVALID                | = 0000001C<br>= 00000124                                                                                                                        |          |                                     |      |    |
| RPSK LENGTH  RPSL ABCNT  RPSL EXTEND  RPSL 10ST2  RPSL 0BCNT  RPSL PID  RPSL PKTASTADR                                            | = 0000005C                             |                            | SS\$ IVBUFLEN                                                      | = 00000340                                                                                                                                      |          |                                     |      |    |
| RPSL PID                                                                                                                          | = 00000044<br>= 0000000C<br>= 00000040 |                            | SSS NORMAL                                                         | = 00000001                                                                                                                                      |          |                                     |      |    |
| KLAF LY IVO ILKU                                                                                                                  | = 00000044                             |                            | SSS PARITY<br>SSS POWERFAIL                                        | = 00000364                                                                                                                                      |          |                                     |      |    |
| RPSM_EXTEND                                                                                                                       | = 0000002C<br>= 00000800               |                            | SS\$_TIMEOUT<br>STARTDATA_FDT                                      | = 00000334<br>= 0000001C<br>= 00000124<br>= 0000035C<br>= 00000001<br>= 00000164<br>= 0000022C<br>00000146<br>00000254<br>0000046F<br>= 0000041 | R        | 03                                  |      |    |
| RPSW_CHAN<br>RPSW_FUNC                                                                                                            | = 00000028<br>= 00000020<br>= 0000008  |                            | STARTIO<br>TIMEOUT                                                 | 00000254<br>0000046F                                                                                                                            | R        | 03<br>03<br>03                      |      |    |
| RPSW_STS                                                                                                                          | = 0000002A                             |                            | UCBSB_DEVCLASS<br>UCBSB_DEVTYPE                                    | = 00000040<br>= 00000041<br>= 0000005E                                                                                                          |          |                                     |      |    |
| RPESB_TYPE<br>RPESL_BBLKADR                                                                                                       | = 0000000A<br>= 0000048                |                            | UCBSB_DIPL<br>UCBSB_FIPL                                           | = 0000005E<br>= 00000008                                                                                                                        |          |                                     |      |    |
| RPESL_BCNT1<br>RPESL_BCNT2                                                                                                        | = 00000034<br>= 00000040               |                            | UCB\$K_SIZE<br>UCB\$L_CRB                                          | = 000000AC<br>= 00000024                                                                                                                        |          |                                     |      |    |
| RPSW FUNC<br>RPSW SIZE<br>RPSW SIS<br>RPESB TYPE<br>RPESL BBLKADR<br>RPESL BCNT1<br>RPESL BCNT2<br>RPESL CBLKADR<br>RPESL SVAPTE1 | = 00000044<br>= 0000002C<br>= 00000038 |                            | UCBSB DIPL UCBSB FIPL UCBSK SIZE UCBSL CRB UCBSL DCR UCBSL DEVCHAR | = 0000000B<br>= 000000AC<br>= 00000024<br>000000A0<br>= 00000038                                                                                |          |                                     |      |    |
| RPESU_SVAPTE2 RPESU_BOFF1                                                                                                         | = 00000030                             |                            | UCBSL DEVDEPEND                                                    | = 00000044<br>= 0000009C                                                                                                                        |          |                                     |      |    |
| RPESW_BOFF2<br>RPESW_STS                                                                                                          | = 0000003C                             |                            | UCB\$L_DPC<br>UCB\$L_IRP<br>UCB\$L_SAVDCR                          | = 00000044<br>= 0000009C<br>= 00000058<br>000000A8                                                                                              |          |                                     |      |    |
| OAD_MICROCODE                                                                                                                     | = 0000002A<br>00000060 R               | 03                         | UCB\$L_SAVSTATUS                                                   | 000000A4                                                                                                                                        |          |                                     |      |    |

16-SEP-1984 00:21:10 VAX/VMS Macro V04-00 Page 41 5-SEP-1984 00:20:00 [DRIVER.SRC]XFDRIVER.MAR;1 (13)

# ! Psect synopsis !

| PSECT name                                     | Allocation                                                                  | PSECT No.                                    | Attributes                                       |                               |                                                           |                                                                             |
|------------------------------------------------|-----------------------------------------------------------------------------|----------------------------------------------|--------------------------------------------------|-------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------|
| *********                                      |                                                                             |                                              |                                                  |                               |                                                           |                                                                             |
| SABSS<br>S\$\$105_PROLOGUE<br>\$\$\$115_DRIVER | 00000000 ( 0.)<br>00000424 ( 1060.)<br>00000058 ( 91.)<br>00000698 ( 1688.) | 00 ( 0.)<br>01 ( 1.)<br>02 ( 2.)<br>03 ( 3.) | NOPIC USR<br>NOPIC USR<br>NOPIC USR<br>NOPIC USR | CON ABS<br>CON REL<br>CON REL | LCL NOSHR NOEXE LCL NOSHR EXE LCL NOSHR EXE LCL NOSHR EXE | NORD NOWRT NOVEC BYTE RD WRT NOVEC BYTE RD WRT NOVEC BYTE RD WRT NOVEC LONG |

# Performance indicators

| Phase                                                               | Page faults | CPU Time    | <b>Elapsed Time</b> |
|---------------------------------------------------------------------|-------------|-------------|---------------------|
| Initialization<br>Command processing<br>Pass 1<br>Symbol table sort | 33          | 00:00:00.02 | 00:00:01.94         |
| Pass 1                                                              | 627         | 00:00:19:10 | 00:01:08.84         |
|                                                                     | 290         | 00:00:04.26 | 00:00:16.90         |
| Symbol table output<br>Psect synopsis output                        | 32          | 00:00:00.02 | 00:00:00.02         |
| Cross-reference output<br>Assembler run totals                      | 1093        | 00:00:26.75 | 00:01:42.93         |

The working set limit was 2400 pages.
159143 bytes (311 pages) of virtual memory were used to buffer the intermediate code.
There were 140 pages of symbol table space allocated to hold 2605 non-local and 65 local symbols.
1703 source lines were read in Pass 1, producing 20 object records in Pass 2.
60 pages of virtual memory were used to define 56 macros.

# ! Macro library statistics !

| Macro Library name                                                                                | Macros defined |
|---------------------------------------------------------------------------------------------------|----------------|
|                                                                                                   |                |
| _\$255\$DUA28:[SYS.OBJ]LIB.MLB;1<br>_\$255\$DUA28:[SYSLIB]STARLET.MLB;2<br>TOTALS (all libraries) | 40<br>11<br>51 |
| _\$255\$DUAZ8:LSYSLIBJSTARLET.MLB;2                                                               | 11             |
| TOTALS (all libraries)                                                                            | 51             |

2870 GETS were required to define 51 macros.

There were no errors, warnings or information messages.

MACRO/LIS=LIS\$:XFDRIVER/OBJ=OBJ\$:XFDRIVER MSRC\$:XFDRIVER/UPDATE=(ENH\$:XFDRIVER)+EXECML\$/LIB

0119 AH-BT13A-SE

DIGITAL EQUIPMENT CORPORATION CONFIDENTIAL AND PROPRIETARY



0120 AH-BT13A-SE

# DIGITAL EQUIPMENT CORPORATION CONFIDENTIAL AND PROPRIETARY

